|
4 | 4 | [string :as str]] |
5 | 5 | [clojure.java.jdbc :as jdbc] |
6 | 6 | [honeysql.core :as hsql] |
| 7 | + [java-time :as t] |
7 | 8 | [metabase.driver :as driver] |
8 | 9 | [metabase.driver.common :as driver.common] |
9 | 10 | [metabase.driver.sql-jdbc |
|
14 | 15 | [metabase.util |
15 | 16 | [honeysql-extensions :as hx] |
16 | 17 | [ssh :as ssh]]) |
17 | | - (:import [java.sql DatabaseMetaData Time])) |
| 18 | + (:import [java.sql DatabaseMetaData Time] |
| 19 | + [java.time LocalDate LocalDateTime LocalTime OffsetDateTime OffsetTime ZonedDateTime])) |
18 | 20 |
|
19 | 21 | (driver/register! :firebird, :parent :sql-jdbc) |
20 | 22 |
|
|
184 | 186 | [driver [_ field]] |
185 | 187 | (hsql/call :stddev_samp (sql.qp/->honeysql driver field))) |
186 | 188 |
|
| 189 | +;; MEGA HACK based on sqlite driver |
| 190 | + |
| 191 | +(defn- zero-time? [t] |
| 192 | + (= (t/local-time t) (t/local-time 0))) |
| 193 | + |
| 194 | +(defmethod sql.qp/->honeysql [:firebird LocalDate] |
| 195 | + [_ t] |
| 196 | + (hx/cast :DATE (t/format "yyyy-MM-dd" t))) |
| 197 | + |
| 198 | +(defmethod sql.qp/->honeysql [:firebird LocalDateTime] |
| 199 | + [driver t] |
| 200 | + (if (zero-time? t) |
| 201 | + (sql.qp/->honeysql driver (t/local-date t)) |
| 202 | + (hx/cast :TIMESTAMP (t/format "yyyy-MM-dd HH:mm:ss.SSSS" t)))) |
| 203 | + |
| 204 | +(defmethod sql.qp/->honeysql [:firebird LocalTime] |
| 205 | + [_ t] |
| 206 | + (hx/cast :TIME (t/format "HH:mm:ss.SSSS" t))) |
| 207 | + |
| 208 | +(defmethod sql.qp/->honeysql [:firebird OffsetDateTime] |
| 209 | + [driver t] |
| 210 | + (if (zero-time? t) |
| 211 | + (sql.qp/->honeysql driver (t/local-date t)) |
| 212 | + (hx/cast :TIMESTAMP (t/format "yyyy-MM-dd HH:mm:ss.SSSS" t)))) |
| 213 | + |
| 214 | +(defmethod sql.qp/->honeysql [:firebird OffsetTime] |
| 215 | + [_ t] |
| 216 | + (hx/cast :TIME (t/format "HH:mm:ss.SSSS" t))) |
| 217 | + |
| 218 | +(defmethod sql.qp/->honeysql [:firebird ZonedDateTime] |
| 219 | + [driver t] |
| 220 | + (if (zero-time? t) |
| 221 | + (sql.qp/->honeysql driver (t/local-date t)) |
| 222 | + (hx/cast :TIMESTAMP (t/format "yyyy-MM-dd HH:mm:ss.SSSS" t)))) |
| 223 | + |
187 | 224 | (defmethod driver/supports? [:firebird :basic-aggregations] [_ _] true) |
188 | 225 |
|
189 | 226 | (defmethod driver/supports? [:firebird :expression-aggregations] [_ _] true) |
|
0 commit comments