More row.spec.ts fixes.
This commit is contained in:
parent
7ab442eae7
commit
2671b9d5ef
|
@ -809,12 +809,35 @@ class InternalBuilder {
|
||||||
const { body } = this.query
|
const { body } = this.query
|
||||||
let query = this.qualifiedKnex({ alias: false })
|
let query = this.qualifiedKnex({ alias: false })
|
||||||
const parsedBody = this.parseBody(body)
|
const parsedBody = this.parseBody(body)
|
||||||
|
|
||||||
|
if (this.client === SqlClient.ORACLE) {
|
||||||
|
// Oracle doesn't seem to automatically insert nulls
|
||||||
|
// if we don't specify them, so we need to do that here
|
||||||
|
for (const [column, schema] of Object.entries(
|
||||||
|
this.query.meta.table.schema
|
||||||
|
)) {
|
||||||
|
if (
|
||||||
|
schema.constraints?.presence === true ||
|
||||||
|
schema.type === FieldType.FORMULA ||
|
||||||
|
schema.type === FieldType.AUTO ||
|
||||||
|
schema.type === FieldType.LINK
|
||||||
|
) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
const value = parsedBody[column]
|
||||||
|
if (value == null) {
|
||||||
|
parsedBody[column] = null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
// make sure no null values in body for creation
|
// make sure no null values in body for creation
|
||||||
for (let [key, value] of Object.entries(parsedBody)) {
|
for (let [key, value] of Object.entries(parsedBody)) {
|
||||||
if (value == null) {
|
if (value == null) {
|
||||||
delete parsedBody[key]
|
delete parsedBody[key]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// mysql can't use returning
|
// mysql can't use returning
|
||||||
if (opts.disableReturning) {
|
if (opts.disableReturning) {
|
||||||
|
|
Loading…
Reference in New Issue