1
import type { Knex } from 'knex';
2
import type { FnHelperOptions } from '../types.js';
3
import { FnHelper } from '../types.js';
5
const parseLocaltime = (columnType?: string) => {
6
if (columnType === 'timestamp') {
7
return ` AT TIME ZONE 'UTC'`;
13
export class FnHelperPostgres extends FnHelper {
14
year(table: string, column: string, options: FnHelperOptions): Knex.Raw {
15
return this.knex.raw(`EXTRACT(YEAR FROM ??.??${parseLocaltime(options?.type)})`, [table, column]);
18
month(table: string, column: string, options: FnHelperOptions): Knex.Raw {
19
return this.knex.raw(`EXTRACT(MONTH FROM ??.??${parseLocaltime(options?.type)})`, [table, column]);
22
week(table: string, column: string, options: FnHelperOptions): Knex.Raw {
23
return this.knex.raw(`EXTRACT(WEEK FROM ??.??${parseLocaltime(options?.type)})`, [table, column]);
26
day(table: string, column: string, options: FnHelperOptions): Knex.Raw {
27
return this.knex.raw(`EXTRACT(DAY FROM ??.??${parseLocaltime(options?.type)})`, [table, column]);
30
weekday(table: string, column: string, options: FnHelperOptions): Knex.Raw {
31
return this.knex.raw(`EXTRACT(DOW FROM ??.??${parseLocaltime(options?.type)})`, [table, column]);
34
hour(table: string, column: string, options: FnHelperOptions): Knex.Raw {
35
return this.knex.raw(`EXTRACT(HOUR FROM ??.??${parseLocaltime(options?.type)})`, [table, column]);
38
minute(table: string, column: string, options: FnHelperOptions): Knex.Raw {
39
return this.knex.raw(`EXTRACT(MINUTE FROM ??.??${parseLocaltime(options?.type)})`, [table, column]);
42
second(table: string, column: string, options: FnHelperOptions): Knex.Raw {
43
return this.knex.raw(`EXTRACT(SECOND FROM ??.??${parseLocaltime(options?.type)})`, [table, column]);
46
count(table: string, column: string, options?: FnHelperOptions): Knex.Raw {
47
const collectionName = options?.originalCollectionName || table;
48
const type = this.schema.collections?.[collectionName]?.fields?.[column]?.type ?? 'unknown';
50
if (type === 'json') {
51
const { dbType } = this.schema.collections[table]!.fields[column]!;
53
return this.knex.raw(dbType === 'jsonb' ? 'jsonb_array_length(??.??)' : 'json_array_length(??.??)', [
59
if (type === 'alias') {
60
return this._relationalCount(table, column, options);
63
throw new Error(`Couldn't extract type from ${table}.${column}`);