mirror of https://github.com/nocodb/nocodb
Pranav C Balan
3 years ago
committed by
Pranav C
7 changed files with 149 additions and 83 deletions
@ -0,0 +1,54 @@
|
||||
import {MapFnArgs} from "../mapFunctionName"; |
||||
|
||||
const mssql = { |
||||
MIN: (args: MapFnArgs) => { |
||||
if (args.pt.arguments.length === 1) { |
||||
return args.fn(args.pt.arguments[0]) |
||||
} |
||||
let query = ''; |
||||
for (const [i, arg] of Object.entries(args.pt.arguments)) { |
||||
if (+i === args.pt.arguments.length - 1) { |
||||
query += args.knex.raw(`\n\tElse ${args.fn(arg).toQuery()}`).toQuery() |
||||
} else { |
||||
query += args.knex.raw(`\n\tWhen ${args.pt.arguments.filter((_, j) => +i !== j).map(arg1 => `${args.fn(arg).toQuery()} < ${args.fn(arg1).toQuery()}`).join(' And ')} Then ${args.fn(arg).toQuery()}`).toQuery() |
||||
} |
||||
} |
||||
return args.knex.raw(`Case ${query}\n End${args.colAlias}`) |
||||
}, |
||||
MAX: (args: MapFnArgs) => { |
||||
if (args.pt.arguments.length === 1) { |
||||
return args.fn(args.pt.arguments[0]) |
||||
} |
||||
let query = ''; |
||||
for (const [i, arg] of Object.entries(args.pt.arguments)) { |
||||
if (+i === args.pt.arguments.length - 1) { |
||||
query += args.knex.raw(`\nElse ${args.fn(arg).toQuery()}`).toQuery() |
||||
} else { |
||||
query += args.knex.raw(`\nWhen ${args.pt.arguments.filter((_, j) => +i !== j).map(arg1 => `${args.fn(arg).toQuery()} > ${args.fn(arg1).toQuery()}`).join(' And ')} Then ${args.fn(arg).toQuery()}`).toQuery() |
||||
} |
||||
} |
||||
|
||||
return args.knex.raw(`Case ${query}\n End${args.colAlias}`) |
||||
}, |
||||
MOD: (pt) => { |
||||
Object.assign(pt, { |
||||
type: 'BinaryExpression', |
||||
operator: '%', |
||||
left: pt.arguments[0], |
||||
right: pt.arguments[1] |
||||
}) |
||||
}, |
||||
REPEAT: 'REPLICATE', |
||||
NOW: 'getdate', |
||||
SEARCH: (args: MapFnArgs) => { |
||||
args.pt.callee.name = 'CHARINDEX'; |
||||
const temp = args.pt.arguments[0] |
||||
args.pt.arguments[0] = args.pt.arguments[1] |
||||
args.pt.arguments[1] = temp; |
||||
}, |
||||
INT: (args: MapFnArgs) => { |
||||
return args.knex.raw(`CASE WHEN ISNUMERIC(${args.fn(args.pt.arguments[0]).toQuery()}) = 1 THEN FLOOR(${args.fn(args.pt.arguments[0]).toQuery()}) ELSE 0 END${args.colAlias}`) |
||||
} |
||||
} |
||||
|
||||
export default mssql; |
@ -0,0 +1,27 @@
|
||||
import {MapFnArgs} from "../mapFunctionName"; |
||||
|
||||
|
||||
const mysql2 = { |
||||
LEN: 'CHAR_LENGTH', |
||||
MIN: 'LEAST', |
||||
MAX: 'GREATEST', |
||||
SEARCH: (args: MapFnArgs) => { |
||||
args.pt.callee.name = 'LOCATE'; |
||||
const temp = args.pt.arguments[0] |
||||
args.pt.arguments[0] = args.pt.arguments[1] |
||||
args.pt.arguments[1] = temp; |
||||
}, |
||||
INT:(args: MapFnArgs) =>{ |
||||
return args.knex.raw(`CAST(${args.fn(args.pt.arguments[0])} as SIGNED)${args.colAlias}`) |
||||
}, |
||||
LEFT:(args: MapFnArgs)=> { |
||||
return args.knex.raw(`SUBSTR(${args.fn(args.pt.arguments[0])},1,${args.fn(args.pt.arguments[1])})${args.colAlias}`) |
||||
}, |
||||
RIGHT:(args: MapFnArgs)=> { |
||||
return args.knex.raw(`SUBSTR(${args.fn(args.pt.arguments[0])},-${args.fn(args.pt.arguments[1])})${args.colAlias}`) |
||||
} |
||||
} |
||||
|
||||
|
||||
export default mysql2; |
||||
|
@ -0,0 +1,21 @@
|
||||
import {MapFnArgs} from "../mapFunctionName"; |
||||
|
||||
const pg = { |
||||
LEN: 'length', |
||||
MIN: 'least', |
||||
MAX: 'greatest', |
||||
CEILING: 'ceil', |
||||
ROUND: 'round', |
||||
POWER: 'pow', |
||||
SQRT: 'sqrt', |
||||
SEARCH: (args: MapFnArgs) => { |
||||
return args.knex.raw(`POSITION(${args.knex.raw(args.fn(args.pt.arguments[1]).toQuery())} in ${args.knex.raw(args.fn(args.pt.arguments[0]).toQuery())})${args.colAlias}`) |
||||
}, |
||||
INT(args: MapFnArgs) { |
||||
// todo: correction
|
||||
return args.knex.raw(`REGEXP_REPLACE(COALESCE(${args.fn(args.pt.arguments[0])}::character varying, '0'), '[^0-9]+|\\.[0-9]+' ,'')${args.colAlias}`) |
||||
} |
||||
} |
||||
|
||||
|
||||
export default pg; |
@ -0,0 +1,30 @@
|
||||
import {MapFnArgs} from "../mapFunctionName"; |
||||
|
||||
|
||||
const sqlite3 = { |
||||
LEN: 'LENGTH', |
||||
CEILING(_pt) { |
||||
// todo:
|
||||
}, FLOOR(_pt) { |
||||
// todo:
|
||||
}, |
||||
MOD:(pt) => { |
||||
Object.assign(pt, { |
||||
type: 'BinaryExpression', |
||||
operator: '%', |
||||
left: pt.arguments[0], |
||||
right: pt.arguments[1] |
||||
}) |
||||
}, |
||||
REPEAT(args: MapFnArgs) { |
||||
return args.knex.raw(`replace(printf('%.' || ${args.fn(args.pt.arguments[1])} || 'c', '/'),'/',${args.fn(args.pt.arguments[0])})${args.colAlias}`) |
||||
}, |
||||
NOW: 'DATE', |
||||
SEARCH:'INSTR', |
||||
INT(args: MapFnArgs) { |
||||
return args.knex.raw(`CAST(${args.fn(args.pt.arguments[0])} as INTEGER)${args.colAlias}`) |
||||
} |
||||
} |
||||
|
||||
|
||||
export default sqlite3; |
Loading…
Reference in new issue