neoorm 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +86 -0
- package/dist/bin/neoorm.d.ts +3 -0
- package/dist/bin/neoorm.d.ts.map +1 -0
- package/dist/bin/neoorm.js +111 -0
- package/dist/bin/neoorm.js.map +1 -0
- package/dist/codegen/emit-includes.d.ts +3 -0
- package/dist/codegen/emit-includes.d.ts.map +1 -0
- package/dist/codegen/emit-includes.js +133 -0
- package/dist/codegen/emit-includes.js.map +1 -0
- package/dist/codegen/generate.d.ts +24 -0
- package/dist/codegen/generate.d.ts.map +1 -0
- package/dist/codegen/generate.js +156 -0
- package/dist/codegen/generate.js.map +1 -0
- package/dist/codegen/schema-to-manifest.d.ts +8 -0
- package/dist/codegen/schema-to-manifest.d.ts.map +1 -0
- package/dist/codegen/schema-to-manifest.js +210 -0
- package/dist/codegen/schema-to-manifest.js.map +1 -0
- package/dist/config.d.ts +11 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +17 -0
- package/dist/config.js.map +1 -0
- package/dist/dialect/index.d.ts +3 -0
- package/dist/dialect/index.d.ts.map +1 -0
- package/dist/dialect/index.js +2 -0
- package/dist/dialect/index.js.map +1 -0
- package/dist/dialect/postgres.d.ts +5 -0
- package/dist/dialect/postgres.d.ts.map +1 -0
- package/dist/dialect/postgres.js +112 -0
- package/dist/dialect/postgres.js.map +1 -0
- package/dist/dialect/types.d.ts +79 -0
- package/dist/dialect/types.d.ts.map +1 -0
- package/dist/dialect/types.js +2 -0
- package/dist/dialect/types.js.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/introspect/pull.d.ts +3 -0
- package/dist/introspect/pull.d.ts.map +1 -0
- package/dist/introspect/pull.js +91 -0
- package/dist/introspect/pull.js.map +1 -0
- package/dist/migrate/runner.d.ts +9 -0
- package/dist/migrate/runner.d.ts.map +1 -0
- package/dist/migrate/runner.js +70 -0
- package/dist/migrate/runner.js.map +1 -0
- package/dist/runtime/client.d.ts +61 -0
- package/dist/runtime/client.d.ts.map +1 -0
- package/dist/runtime/client.js +54 -0
- package/dist/runtime/client.js.map +1 -0
- package/dist/runtime/executor.d.ts +10 -0
- package/dist/runtime/executor.d.ts.map +1 -0
- package/dist/runtime/executor.js +62 -0
- package/dist/runtime/executor.js.map +1 -0
- package/dist/runtime/query/compile.d.ts +23 -0
- package/dist/runtime/query/compile.d.ts.map +1 -0
- package/dist/runtime/query/compile.js +182 -0
- package/dist/runtime/query/compile.js.map +1 -0
- package/dist/runtime/query/create.d.ts +8 -0
- package/dist/runtime/query/create.d.ts.map +1 -0
- package/dist/runtime/query/create.js +139 -0
- package/dist/runtime/query/create.js.map +1 -0
- package/dist/runtime/query/delete.d.ts +12 -0
- package/dist/runtime/query/delete.d.ts.map +1 -0
- package/dist/runtime/query/delete.js +35 -0
- package/dist/runtime/query/delete.js.map +1 -0
- package/dist/runtime/query/find.d.ts +21 -0
- package/dist/runtime/query/find.d.ts.map +1 -0
- package/dist/runtime/query/find.js +172 -0
- package/dist/runtime/query/find.js.map +1 -0
- package/dist/runtime/query/update.d.ts +17 -0
- package/dist/runtime/query/update.d.ts.map +1 -0
- package/dist/runtime/query/update.js +63 -0
- package/dist/runtime/query/update.js.map +1 -0
- package/dist/runtime/types.d.ts +48 -0
- package/dist/runtime/types.d.ts.map +1 -0
- package/dist/runtime/types.js +2 -0
- package/dist/runtime/types.js.map +1 -0
- package/dist/schema/column.d.ts +39 -0
- package/dist/schema/column.d.ts.map +1 -0
- package/dist/schema/column.js +70 -0
- package/dist/schema/column.js.map +1 -0
- package/dist/schema/define-schema.d.ts +6 -0
- package/dist/schema/define-schema.d.ts.map +1 -0
- package/dist/schema/define-schema.js +4 -0
- package/dist/schema/define-schema.js.map +1 -0
- package/dist/schema/index.d.ts +13 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js +6 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/many-to-many.d.ts +21 -0
- package/dist/schema/many-to-many.d.ts.map +1 -0
- package/dist/schema/many-to-many.js +20 -0
- package/dist/schema/many-to-many.js.map +1 -0
- package/dist/schema/relation-types.d.ts +74 -0
- package/dist/schema/relation-types.d.ts.map +1 -0
- package/dist/schema/relation-types.js +2 -0
- package/dist/schema/relation-types.js.map +1 -0
- package/dist/schema/relation.d.ts +24 -0
- package/dist/schema/relation.d.ts.map +1 -0
- package/dist/schema/relation.js +25 -0
- package/dist/schema/relation.js.map +1 -0
- package/dist/schema/table.d.ts +28 -0
- package/dist/schema/table.d.ts.map +1 -0
- package/dist/schema/table.js +23 -0
- package/dist/schema/table.js.map +1 -0
- package/dist/schema/types.d.ts +115 -0
- package/dist/schema/types.d.ts.map +1 -0
- package/dist/schema/types.js +2 -0
- package/dist/schema/types.js.map +1 -0
- package/dist/sql/builder.d.ts +17 -0
- package/dist/sql/builder.d.ts.map +1 -0
- package/dist/sql/builder.js +51 -0
- package/dist/sql/builder.js.map +1 -0
- package/dist/sql/index.d.ts +7 -0
- package/dist/sql/index.d.ts.map +1 -0
- package/dist/sql/index.js +6 -0
- package/dist/sql/index.js.map +1 -0
- package/dist/sql/template.d.ts +16 -0
- package/dist/sql/template.d.ts.map +1 -0
- package/dist/sql/template.js +43 -0
- package/dist/sql/template.js.map +1 -0
- package/dist/utils/case.d.ts +5 -0
- package/dist/utils/case.d.ts.map +1 -0
- package/dist/utils/case.js +20 -0
- package/dist/utils/case.js.map +1 -0
- package/package.json +60 -0
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import { randomUUID } from "node:crypto";
|
|
2
|
+
import { quoteIdentifier } from "../../dialect/postgres.js";
|
|
3
|
+
import { buildInsertQuery, dataToSqlValues, rowToTs, } from "./compile.js";
|
|
4
|
+
import { loadRelations } from "./find.js";
|
|
5
|
+
function generateId(tableAccessor) {
|
|
6
|
+
const prefix = tableAccessor.replace(/s$/, "").slice(0, 4);
|
|
7
|
+
return `${prefix}_${randomUUID().slice(0, 8)}`;
|
|
8
|
+
}
|
|
9
|
+
async function resolveConnectOrCreate(executor, manifest, targetAccessor, items) {
|
|
10
|
+
const ids = [];
|
|
11
|
+
const targetTable = manifest.tables[targetAccessor];
|
|
12
|
+
if (!targetTable)
|
|
13
|
+
throw new Error(`Unknown table: ${targetAccessor}`);
|
|
14
|
+
for (const item of items) {
|
|
15
|
+
const whereKey = Object.keys(item.where)[0];
|
|
16
|
+
const whereVal = item.where[whereKey];
|
|
17
|
+
if (whereKey && whereVal !== undefined) {
|
|
18
|
+
const col = targetTable.columns.find((c) => c.tsName === whereKey);
|
|
19
|
+
const sqlCol = col ? quoteIdentifier(col.sqlName) : quoteIdentifier(whereKey);
|
|
20
|
+
const existing = await executor.queryOne(`SELECT id FROM ${quoteIdentifier(targetTable.sqlName)} WHERE ${sqlCol} = $1 LIMIT 1`, [whereVal]);
|
|
21
|
+
if (existing) {
|
|
22
|
+
ids.push(String(existing["id"]));
|
|
23
|
+
continue;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
const createData = { ...item.create };
|
|
27
|
+
if (!createData["id"]) {
|
|
28
|
+
createData["id"] = generateId(targetAccessor);
|
|
29
|
+
}
|
|
30
|
+
const { keys, values } = dataToSqlValues(targetTable, createData);
|
|
31
|
+
if (!keys.includes("id")) {
|
|
32
|
+
keys.unshift("id");
|
|
33
|
+
values.unshift(createData["id"]);
|
|
34
|
+
}
|
|
35
|
+
const sql = buildInsertQuery(targetTable, keys);
|
|
36
|
+
const row = await executor.queryOne(sql, values);
|
|
37
|
+
if (row)
|
|
38
|
+
ids.push(String(row["id"]));
|
|
39
|
+
}
|
|
40
|
+
return ids;
|
|
41
|
+
}
|
|
42
|
+
async function insertJunctionRows(executor, manifest, throughAccessor, leftFkCol, rightFkCol, leftId, rightIds, extraData) {
|
|
43
|
+
const throughTable = manifest.tables[throughAccessor];
|
|
44
|
+
if (!throughTable)
|
|
45
|
+
return;
|
|
46
|
+
const leftCol = throughTable.columns.find((c) => c.sqlName === leftFkCol);
|
|
47
|
+
const rightCol = throughTable.columns.find((c) => c.sqlName === rightFkCol);
|
|
48
|
+
if (!leftCol || !rightCol)
|
|
49
|
+
return;
|
|
50
|
+
for (const rightId of rightIds) {
|
|
51
|
+
const data = {
|
|
52
|
+
[leftCol.tsName]: leftId,
|
|
53
|
+
[rightCol.tsName]: rightId,
|
|
54
|
+
...extraData,
|
|
55
|
+
};
|
|
56
|
+
for (const col of throughTable.columns) {
|
|
57
|
+
if (col.tsName in data)
|
|
58
|
+
continue;
|
|
59
|
+
if (col.defaultNow) {
|
|
60
|
+
data[col.tsName] = new Date();
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
const { keys, values } = dataToSqlValues(throughTable, data);
|
|
64
|
+
const sql = buildInsertQuery(throughTable, keys);
|
|
65
|
+
await executor.query(sql, values);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
export async function createRecord(executor, manifest, tableAccessor, args) {
|
|
69
|
+
const table = manifest.tables[tableAccessor];
|
|
70
|
+
if (!table)
|
|
71
|
+
throw new Error(`Unknown table: ${tableAccessor}`);
|
|
72
|
+
return executor.transaction(async (tx) => {
|
|
73
|
+
const scalarData = {};
|
|
74
|
+
const relationWrites = [];
|
|
75
|
+
for (const [key, value] of Object.entries(args.data)) {
|
|
76
|
+
const col = table.columns.find((c) => c.tsName === key);
|
|
77
|
+
if (col) {
|
|
78
|
+
scalarData[key] = value;
|
|
79
|
+
continue;
|
|
80
|
+
}
|
|
81
|
+
const rel = table.relations.find((r) => r.name === key);
|
|
82
|
+
if (rel && value && typeof value === "object") {
|
|
83
|
+
const relValue = value;
|
|
84
|
+
if ("connect" in relValue) {
|
|
85
|
+
relationWrites.push({ relationName: key, type: "connect", value: relValue["connect"] });
|
|
86
|
+
}
|
|
87
|
+
else if ("connectOrCreate" in relValue) {
|
|
88
|
+
relationWrites.push({
|
|
89
|
+
relationName: key,
|
|
90
|
+
type: "connectOrCreate",
|
|
91
|
+
value: relValue["connectOrCreate"],
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
if (!scalarData["id"]) {
|
|
97
|
+
scalarData["id"] = generateId(tableAccessor);
|
|
98
|
+
}
|
|
99
|
+
for (const write of relationWrites) {
|
|
100
|
+
if (write.type === "connect") {
|
|
101
|
+
const connect = write.value;
|
|
102
|
+
const rel = table.relations.find((r) => r.name === write.relationName);
|
|
103
|
+
if (rel && rel.cardinality === "one") {
|
|
104
|
+
scalarData[rel.fkColumn] = connect.id;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
const { keys, values } = dataToSqlValues(table, scalarData);
|
|
109
|
+
if (!keys.includes("id")) {
|
|
110
|
+
keys.unshift("id");
|
|
111
|
+
values.unshift(scalarData["id"]);
|
|
112
|
+
}
|
|
113
|
+
const insertSql = buildInsertQuery(table, keys);
|
|
114
|
+
const row = await tx.queryOne(insertSql, values);
|
|
115
|
+
if (!row)
|
|
116
|
+
throw new Error("Insert failed");
|
|
117
|
+
const result = rowToTs(table, row);
|
|
118
|
+
const recordId = String(result["id"]);
|
|
119
|
+
for (const write of relationWrites) {
|
|
120
|
+
if (write.type === "connectOrCreate") {
|
|
121
|
+
const m2m = manifest.manyToMany.find((m) => (m.leftAccessor === tableAccessor && m.as === write.relationName) ||
|
|
122
|
+
(m.rightAccessor === tableAccessor && m.inverse === write.relationName));
|
|
123
|
+
if (m2m) {
|
|
124
|
+
const isLeft = m2m.leftAccessor === tableAccessor;
|
|
125
|
+
const targetAccessor = isLeft ? m2m.rightAccessor : m2m.leftAccessor;
|
|
126
|
+
const items = write.value;
|
|
127
|
+
const ids = await resolveConnectOrCreate(tx, manifest, targetAccessor, items);
|
|
128
|
+
await insertJunctionRows(tx, manifest, m2m.throughAccessor, m2m.leftFkColumn, m2m.rightFkColumn, recordId, ids);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
if (args.with) {
|
|
133
|
+
const [withLoaded] = await loadRelations(tx, manifest, table, [result], args.with);
|
|
134
|
+
return withLoaded ?? result;
|
|
135
|
+
}
|
|
136
|
+
return result;
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
//# sourceMappingURL=create.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/runtime/query/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAGzC,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EACL,gBAAgB,EAChB,eAAe,EACf,OAAO,GACR,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,aAAa,EAAkB,MAAM,WAAW,CAAC;AAE1D,SAAS,UAAU,CAAC,aAAqB;IACvC,MAAM,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC3D,OAAO,GAAG,MAAM,IAAI,UAAU,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;AACjD,CAAC;AAED,KAAK,UAAU,sBAAsB,CACnC,QAAkB,EAClB,QAAkB,EAClB,cAAsB,EACtB,KAAiF;IAEjF,MAAM,GAAG,GAAa,EAAE,CAAC;IACzB,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;IACpD,IAAI,CAAC,WAAW;QAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,cAAc,EAAE,CAAC,CAAC;IAEtE,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5C,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAS,CAAC,CAAC;QAEvC,IAAI,QAAQ,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;YACvC,MAAM,GAAG,GAAG,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC;YACnE,MAAM,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,eAAe,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;YAC9E,MAAM,QAAQ,GAAG,MAAM,QAAQ,CAAC,QAAQ,CACtC,kBAAkB,eAAe,CAAC,WAAW,CAAC,OAAO,CAAC,UAAU,MAAM,eAAe,EACrF,CAAC,QAAQ,CAAC,CACX,CAAC;YAEF,IAAI,QAAQ,EAAE,CAAC;gBACb,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACjC,SAAS;YACX,CAAC;QACH,CAAC;QAED,MAAM,UAAU,GAAG,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACtB,UAAU,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,cAAc,CAAC,CAAC;QAChD,CAAC;QAED,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,eAAe,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;QAClE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACnB,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;QACnC,CAAC;QAED,MAAM,GAAG,GAAG,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;QAChD,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QACjD,IAAI,GAAG;YAAE,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACvC,CAAC;IAED,OAAO,GAAG,CAAC;AACb,CAAC;AAED,KAAK,UAAU,kBAAkB,CAC/B,QAAkB,EAClB,QAAkB,EAClB,eAAuB,EACvB,SAAiB,EACjB,UAAkB,EAClB,MAAc,EACd,QAAkB,EAClB,SAAmC;IAEnC,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;IACtD,IAAI,CAAC,YAAY;QAAE,OAAO;IAE1B,MAAM,OAAO,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC;IAC1E,MAAM,QAAQ,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,UAAU,CAAC,CAAC;IAC5E,IAAI,CAAC,OAAO,IAAI,CAAC,QAAQ;QAAE,OAAO;IAElC,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,MAAM,IAAI,GAA4B;YACpC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,MAAM;YACxB,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,OAAO;YAC1B,GAAG,SAAS;SACb,CAAC;QAEF,KAAK,MAAM,GAAG,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;YACvC,IAAI,GAAG,CAAC,MAAM,IAAI,IAAI;gBAAE,SAAS;YACjC,IAAI,GAAG,CAAC,UAAU,EAAE,CAAC;gBACnB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC;YAChC,CAAC;QACH,CAAC;QAED,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,eAAe,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QAC7D,MAAM,GAAG,GAAG,gBAAgB,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QACjD,MAAM,QAAQ,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IACpC,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,QAAkB,EAClB,QAAkB,EAClB,aAAqB,EACrB,IAGC;IAED,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAC7C,IAAI,CAAC,KAAK;QAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,aAAa,EAAE,CAAC,CAAC;IAE/D,OAAO,QAAQ,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE;QACvC,MAAM,UAAU,GAA4B,EAAE,CAAC;QAC/C,MAAM,cAAc,GAIf,EAAE,CAAC;QAER,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YACrD,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,GAAG,CAAC,CAAC;YACxD,IAAI,GAAG,EAAE,CAAC;gBACR,UAAU,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;gBACxB,SAAS;YACX,CAAC;YAED,MAAM,GAAG,GAAG,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC,CAAC;YACxD,IAAI,GAAG,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;gBAC9C,MAAM,QAAQ,GAAG,KAAgC,CAAC;gBAClD,IAAI,SAAS,IAAI,QAAQ,EAAE,CAAC;oBAC1B,cAAc,CAAC,IAAI,CAAC,EAAE,YAAY,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;gBAC1F,CAAC;qBAAM,IAAI,iBAAiB,IAAI,QAAQ,EAAE,CAAC;oBACzC,cAAc,CAAC,IAAI,CAAC;wBAClB,YAAY,EAAE,GAAG;wBACjB,IAAI,EAAE,iBAAiB;wBACvB,KAAK,EAAE,QAAQ,CAAC,iBAAiB,CAAC;qBACnC,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACtB,UAAU,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,aAAa,CAAC,CAAC;QAC/C,CAAC;QAED,KAAK,MAAM,KAAK,IAAI,cAAc,EAAE,CAAC;YACnC,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;gBAC7B,MAAM,OAAO,GAAG,KAAK,CAAC,KAAuB,CAAC;gBAC9C,MAAM,GAAG,GAAG,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,KAAK,CAAC,YAAY,CAAC,CAAC;gBACvE,IAAI,GAAG,IAAI,GAAG,CAAC,WAAW,KAAK,KAAK,EAAE,CAAC;oBACrC,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC,EAAE,CAAC;gBACxC,CAAC;YACH,CAAC;QACH,CAAC;QAED,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,eAAe,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;QAC5D,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACnB,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;QACnC,CAAC;QAED,MAAM,SAAS,GAAG,gBAAgB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAChD,MAAM,GAAG,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QACjD,IAAI,CAAC,GAAG;YAAE,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;QAE3C,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QACnC,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QAEtC,KAAK,MAAM,KAAK,IAAI,cAAc,EAAE,CAAC;YACnC,IAAI,KAAK,CAAC,IAAI,KAAK,iBAAiB,EAAE,CAAC;gBACrC,MAAM,GAAG,GAAG,QAAQ,CAAC,UAAU,CAAC,IAAI,CAClC,CAAC,CAAC,EAAE,EAAE,CACJ,CAAC,CAAC,CAAC,YAAY,KAAK,aAAa,IAAI,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,YAAY,CAAC;oBACjE,CAAC,CAAC,CAAC,aAAa,KAAK,aAAa,IAAI,CAAC,CAAC,OAAO,KAAK,KAAK,CAAC,YAAY,CAAC,CAC1E,CAAC;gBAEF,IAAI,GAAG,EAAE,CAAC;oBACR,MAAM,MAAM,GAAG,GAAG,CAAC,YAAY,KAAK,aAAa,CAAC;oBAClD,MAAM,cAAc,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,YAAY,CAAC;oBACrE,MAAM,KAAK,GAAG,KAAK,CAAC,KAGlB,CAAC;oBACH,MAAM,GAAG,GAAG,MAAM,sBAAsB,CAAC,EAAE,EAAE,QAAQ,EAAE,cAAc,EAAE,KAAK,CAAC,CAAC;oBAE9E,MAAM,kBAAkB,CACtB,EAAE,EACF,QAAQ,EACR,GAAG,CAAC,eAAe,EACnB,GAAG,CAAC,YAAY,EAChB,GAAG,CAAC,aAAa,EACjB,QAAQ,EACR,GAAG,CACJ,CAAC;gBACJ,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,MAAM,CAAC,UAAU,CAAC,GAAG,MAAM,aAAa,CAAC,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACnF,OAAO,UAAU,IAAI,MAAM,CAAC;QAC9B,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Manifest } from "../../dialect/types.js";
|
|
2
|
+
import type { Executor } from "../executor.js";
|
|
3
|
+
import { type WithInput } from "./find.js";
|
|
4
|
+
export declare function deleteRecord(executor: Executor, manifest: Manifest, tableAccessor: string, args: {
|
|
5
|
+
where: Record<string, unknown>;
|
|
6
|
+
with?: Record<string, WithInput>;
|
|
7
|
+
}): Promise<Record<string, unknown> | null>;
|
|
8
|
+
export declare function deleteManyRecords(executor: Executor, manifest: Manifest, tableAccessor: string, args?: {
|
|
9
|
+
where?: Record<string, unknown>;
|
|
10
|
+
}): Promise<number>;
|
|
11
|
+
export declare function deleteById(executor: Executor, manifest: Manifest, tableAccessor: string, id: string): Promise<Record<string, unknown> | null>;
|
|
12
|
+
//# sourceMappingURL=delete.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/delete.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAQ/C,OAAO,EAAiB,KAAK,SAAS,EAAE,MAAM,WAAW,CAAC;AAE1D,wBAAsB,YAAY,CAChC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,EAAE;IACJ,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CA0BzC;AAED,wBAAsB,iBAAiB,CACrC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,CAAC,EAAE;IACL,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACjC,GACA,OAAO,CAAC,MAAM,CAAC,CAajB;AAED,wBAAsB,UAAU,CAC9B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,EAAE,EAAE,MAAM,GACT,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAEzC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { postgresDialect } from "../../dialect/postgres.js";
|
|
2
|
+
import { buildDeleteQuery, buildDeleteManyQuery, compileWhere, rowToTs, } from "./compile.js";
|
|
3
|
+
import { loadRelations } from "./find.js";
|
|
4
|
+
export async function deleteRecord(executor, manifest, tableAccessor, args) {
|
|
5
|
+
const table = manifest.tables[tableAccessor];
|
|
6
|
+
if (!table)
|
|
7
|
+
throw new Error(`Unknown table: ${tableAccessor}`);
|
|
8
|
+
const { sql: whereSql, params } = compileWhere(table, args.where, postgresDialect);
|
|
9
|
+
if (!whereSql) {
|
|
10
|
+
throw new Error("Delete requires a where clause");
|
|
11
|
+
}
|
|
12
|
+
const query = buildDeleteQuery(table, whereSql);
|
|
13
|
+
const row = await executor.queryOne(query, params);
|
|
14
|
+
if (!row)
|
|
15
|
+
return null;
|
|
16
|
+
const result = rowToTs(table, row);
|
|
17
|
+
if (args.with) {
|
|
18
|
+
const [withLoaded] = await loadRelations(executor, manifest, table, [result], args.with);
|
|
19
|
+
return withLoaded ?? result;
|
|
20
|
+
}
|
|
21
|
+
return result;
|
|
22
|
+
}
|
|
23
|
+
export async function deleteManyRecords(executor, manifest, tableAccessor, args) {
|
|
24
|
+
const table = manifest.tables[tableAccessor];
|
|
25
|
+
if (!table)
|
|
26
|
+
throw new Error(`Unknown table: ${tableAccessor}`);
|
|
27
|
+
const { sql: whereSql, params } = compileWhere(table, args?.where, postgresDialect);
|
|
28
|
+
const query = buildDeleteManyQuery(table, whereSql);
|
|
29
|
+
const result = await executor.query(`${query} RETURNING id`, params);
|
|
30
|
+
return result.length;
|
|
31
|
+
}
|
|
32
|
+
export async function deleteById(executor, manifest, tableAccessor, id) {
|
|
33
|
+
return deleteRecord(executor, manifest, tableAccessor, { where: { id } });
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=delete.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete.js","sourceRoot":"","sources":["../../../src/runtime/query/delete.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EACL,gBAAgB,EAChB,oBAAoB,EACpB,YAAY,EACZ,OAAO,GACR,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,aAAa,EAAkB,MAAM,WAAW,CAAC;AAE1D,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,QAAkB,EAClB,QAAkB,EAClB,aAAqB,EACrB,IAGC;IAED,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAC7C,IAAI,CAAC,KAAK;QAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,aAAa,EAAE,CAAC,CAAC;IAE/D,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,YAAY,CAC5C,KAAK,EACL,IAAI,CAAC,KAAK,EACV,eAAe,CAChB,CAAC;IAEF,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;IACpD,CAAC;IAED,MAAM,KAAK,GAAG,gBAAgB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IAChD,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACnD,IAAI,CAAC,GAAG;QAAE,OAAO,IAAI,CAAC;IAEtB,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAEnC,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;QACd,MAAM,CAAC,UAAU,CAAC,GAAG,MAAM,aAAa,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QACzF,OAAO,UAAU,IAAI,MAAM,CAAC;IAC9B,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,QAAkB,EAClB,QAAkB,EAClB,aAAqB,EACrB,IAEC;IAED,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAC7C,IAAI,CAAC,KAAK;QAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,aAAa,EAAE,CAAC,CAAC;IAE/D,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,YAAY,CAC5C,KAAK,EACL,IAAI,EAAE,KAAK,EACX,eAAe,CAChB,CAAC;IAEF,MAAM,KAAK,GAAG,oBAAoB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IACpD,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,KAAK,CAAC,GAAG,KAAK,eAAe,EAAE,MAAM,CAAC,CAAC;IACrE,OAAO,MAAM,CAAC,MAAM,CAAC;AACvB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,QAAkB,EAClB,QAAkB,EAClB,aAAqB,EACrB,EAAU;IAEV,OAAO,YAAY,CAAC,QAAQ,EAAE,QAAQ,EAAE,aAAa,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;AAC5E,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { Manifest, ManifestTable } from "../../dialect/types.js";
|
|
2
|
+
import type { Executor } from "../executor.js";
|
|
3
|
+
export type WithInput = boolean | {
|
|
4
|
+
select?: readonly string[] | Record<string, boolean | undefined>;
|
|
5
|
+
orderBy?: Record<string, string>;
|
|
6
|
+
limit?: number;
|
|
7
|
+
with?: Record<string, WithInput>;
|
|
8
|
+
};
|
|
9
|
+
export declare function loadRelations(executor: Executor, manifest: Manifest, table: ManifestTable, rows: Record<string, unknown>[], withSpec: Record<string, WithInput> | undefined): Promise<Record<string, unknown>[]>;
|
|
10
|
+
export declare function findMany(executor: Executor, manifest: Manifest, tableAccessor: string, args?: {
|
|
11
|
+
where?: Record<string, unknown>;
|
|
12
|
+
orderBy?: Record<string, string>;
|
|
13
|
+
limit?: number;
|
|
14
|
+
offset?: number;
|
|
15
|
+
with?: Record<string, WithInput>;
|
|
16
|
+
}): Promise<Record<string, unknown>[]>;
|
|
17
|
+
export declare function findFirst(executor: Executor, manifest: Manifest, tableAccessor: string, args?: Parameters<typeof findMany>[3]): Promise<Record<string, unknown> | null>;
|
|
18
|
+
export declare function findById(executor: Executor, manifest: Manifest, tableAccessor: string, id: string, args?: {
|
|
19
|
+
with?: Record<string, WithInput>;
|
|
20
|
+
}): Promise<Record<string, unknown> | null>;
|
|
21
|
+
//# sourceMappingURL=find.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/find.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAwC,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAC5G,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAY/C,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG;IAChC,MAAM,CAAC,EAAE,SAAS,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;IACjE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,CAAC;AA0MF,wBAAsB,aAAa,CACjC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,aAAa,EACpB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,EAC/B,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,SAAS,GAC9C,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAQpC;AAED,wBAAsB,QAAQ,CAC5B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,CAAC,EAAE;IACL,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,CAqBpC;AAED,wBAAsB,SAAS,CAC7B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,CAAC,EAAE,UAAU,CAAC,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC,GACpC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAMzC;AAED,wBAAsB,QAAQ,CAC5B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,EAAE,EAAE,MAAM,EACV,IAAI,CAAC,EAAE;IAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAA;CAAE,GAC1C,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAazC"}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { postgresDialect, quoteIdentifier } from "../../dialect/postgres.js";
|
|
2
|
+
import { buildFindManyQuery, buildSelectColumns, compileOrderBy, compileWhere, normalizeSelectColumns, rowToTs, rowsToTs, } from "./compile.js";
|
|
3
|
+
function columnsForSelect(table, withSpec) {
|
|
4
|
+
const nestedSpec = typeof withSpec === "object" ? withSpec : undefined;
|
|
5
|
+
const selectKeys = normalizeSelectColumns(nestedSpec?.select);
|
|
6
|
+
return buildSelectColumns(table, selectKeys ? [...selectKeys] : undefined);
|
|
7
|
+
}
|
|
8
|
+
function findM2M(manifest, tableAccessor, relationName) {
|
|
9
|
+
return manifest.manyToMany.find((m) => (m.leftAccessor === tableAccessor && m.as === relationName) ||
|
|
10
|
+
(m.rightAccessor === tableAccessor && m.inverse === relationName));
|
|
11
|
+
}
|
|
12
|
+
function findRelation(table, name) {
|
|
13
|
+
return table.relations.find((r) => r.name === name);
|
|
14
|
+
}
|
|
15
|
+
function isM2MRelation(manifest, tableAccessor, relationName) {
|
|
16
|
+
return findM2M(manifest, tableAccessor, relationName) !== undefined;
|
|
17
|
+
}
|
|
18
|
+
async function loadOneRelation(executor, manifest, parentTable, parentRows, relationName, withSpec) {
|
|
19
|
+
if (parentRows.length === 0)
|
|
20
|
+
return;
|
|
21
|
+
const m2m = findM2M(manifest, parentTable.accessor, relationName);
|
|
22
|
+
if (m2m) {
|
|
23
|
+
await loadM2MRelation(executor, manifest, parentTable, parentRows, m2m, relationName, withSpec);
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const relation = findRelation(parentTable, relationName);
|
|
27
|
+
if (!relation)
|
|
28
|
+
return;
|
|
29
|
+
const targetTable = manifest.tables[relation.targetAccessor];
|
|
30
|
+
if (!targetTable)
|
|
31
|
+
return;
|
|
32
|
+
const parentIds = parentRows.map((r) => r["id"]).filter(Boolean);
|
|
33
|
+
if (relation.cardinality === "one") {
|
|
34
|
+
const fkValues = parentRows
|
|
35
|
+
.map((r) => r[relation.fkColumn])
|
|
36
|
+
.filter((v) => v != null);
|
|
37
|
+
if (fkValues.length === 0)
|
|
38
|
+
return;
|
|
39
|
+
const placeholders = fkValues.map((_, i) => `$${i + 1}`).join(", ");
|
|
40
|
+
const idCol = quoteIdentifier("id");
|
|
41
|
+
const selectCols = columnsForSelect(targetTable, withSpec);
|
|
42
|
+
const rows = await executor.query(`SELECT ${selectCols} FROM ${quoteIdentifier(targetTable.sqlName)} WHERE ${idCol} IN (${placeholders})`, fkValues);
|
|
43
|
+
const mapped = rowsToTs(targetTable, rows);
|
|
44
|
+
const byId = new Map(mapped.map((r) => [r["id"], r]));
|
|
45
|
+
for (const parent of parentRows) {
|
|
46
|
+
const fkVal = parent[relation.fkColumn];
|
|
47
|
+
parent[relationName] = fkVal != null ? byId.get(fkVal) ?? null : null;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
const fkCol = quoteIdentifier(relation.fkSqlColumn);
|
|
52
|
+
const placeholders = parentIds.map((_, i) => `$${i + 1}`).join(", ");
|
|
53
|
+
const selectCols = columnsForSelect(targetTable, withSpec);
|
|
54
|
+
let sql = `SELECT ${selectCols} FROM ${quoteIdentifier(targetTable.sqlName)} WHERE ${fkCol} IN (${placeholders})`;
|
|
55
|
+
const nestedSpec = typeof withSpec === "object" ? withSpec : undefined;
|
|
56
|
+
if (nestedSpec?.orderBy) {
|
|
57
|
+
sql += ` ${compileOrderBy(targetTable, nestedSpec.orderBy)}`;
|
|
58
|
+
}
|
|
59
|
+
if (nestedSpec?.limit !== undefined) {
|
|
60
|
+
sql += ` LIMIT ${nestedSpec.limit}`;
|
|
61
|
+
}
|
|
62
|
+
const rows = await executor.query(sql, parentIds);
|
|
63
|
+
const mapped = rowsToTs(targetTable, rows);
|
|
64
|
+
const grouped = new Map();
|
|
65
|
+
for (const row of mapped) {
|
|
66
|
+
const fkVal = String(row[relation.fkColumn] ?? row[relation.fkSqlColumn.replace(/_([a-z])/g, (_, c) => c.toUpperCase())]);
|
|
67
|
+
const fkKey = Object.keys(row).find((k) => k.endsWith("Id") && row[k] === fkVal) ?? relation.fkColumn;
|
|
68
|
+
const parentFk = row[fkKey] ?? row[relation.fkColumn];
|
|
69
|
+
const key = String(parentFk);
|
|
70
|
+
if (!grouped.has(key))
|
|
71
|
+
grouped.set(key, []);
|
|
72
|
+
grouped.get(key).push(row);
|
|
73
|
+
}
|
|
74
|
+
for (const parent of parentRows) {
|
|
75
|
+
const id = String(parent["id"]);
|
|
76
|
+
parent[relationName] = grouped.get(id) ?? [];
|
|
77
|
+
}
|
|
78
|
+
if (nestedSpec?.with) {
|
|
79
|
+
for (const childRows of grouped.values()) {
|
|
80
|
+
for (const [nestedName, nestedWith] of Object.entries(nestedSpec.with)) {
|
|
81
|
+
await loadOneRelation(executor, manifest, targetTable, childRows, nestedName, nestedWith);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
const nestedSpec = typeof withSpec === "object" ? withSpec : undefined;
|
|
87
|
+
if (nestedSpec?.with && relation.cardinality === "one") {
|
|
88
|
+
const childRows = parentRows
|
|
89
|
+
.map((p) => p[relationName])
|
|
90
|
+
.filter((r) => r != null && typeof r === "object");
|
|
91
|
+
for (const [nestedName, nestedWith] of Object.entries(nestedSpec.with)) {
|
|
92
|
+
await loadOneRelation(executor, manifest, targetTable, childRows, nestedName, nestedWith);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
async function loadM2MRelation(executor, manifest, parentTable, parentRows, m2m, relationName, withSpec) {
|
|
97
|
+
const isLeft = m2m.leftAccessor === parentTable.accessor;
|
|
98
|
+
const targetAccessor = isLeft ? m2m.rightAccessor : m2m.leftAccessor;
|
|
99
|
+
const targetTable = manifest.tables[targetAccessor];
|
|
100
|
+
const throughTable = manifest.tables[m2m.throughAccessor];
|
|
101
|
+
if (!targetTable || !throughTable)
|
|
102
|
+
return;
|
|
103
|
+
const parentFkCol = isLeft ? m2m.leftFkColumn : m2m.rightFkColumn;
|
|
104
|
+
const targetFkCol = isLeft ? m2m.rightFkColumn : m2m.leftFkColumn;
|
|
105
|
+
const parentIds = parentRows.map((r) => r["id"]).filter(Boolean);
|
|
106
|
+
if (parentIds.length === 0)
|
|
107
|
+
return;
|
|
108
|
+
const placeholders = parentIds.map((_, i) => `$${i + 1}`).join(", ");
|
|
109
|
+
const selectCols = targetTable.columns
|
|
110
|
+
.map((c) => quoteIdentifier(c.sqlName))
|
|
111
|
+
.join(", ");
|
|
112
|
+
const sql = `
|
|
113
|
+
SELECT t.*, j.${quoteIdentifier(parentFkCol)} AS _parent_id
|
|
114
|
+
FROM ${quoteIdentifier(throughTable.sqlName)} j
|
|
115
|
+
JOIN ${quoteIdentifier(targetTable.sqlName)} t ON t.${quoteIdentifier("id")} = j.${quoteIdentifier(targetFkCol)}
|
|
116
|
+
WHERE j.${quoteIdentifier(parentFkCol)} IN (${placeholders})
|
|
117
|
+
`.trim();
|
|
118
|
+
const rows = await executor.query(sql, parentIds);
|
|
119
|
+
const grouped = new Map();
|
|
120
|
+
for (const row of rows) {
|
|
121
|
+
const parentId = String(row["_parent_id"]);
|
|
122
|
+
const mapped = rowToTs(targetTable, row);
|
|
123
|
+
if (!grouped.has(parentId))
|
|
124
|
+
grouped.set(parentId, []);
|
|
125
|
+
grouped.get(parentId).push(mapped);
|
|
126
|
+
}
|
|
127
|
+
for (const parent of parentRows) {
|
|
128
|
+
const id = String(parent["id"]);
|
|
129
|
+
parent[relationName] = grouped.get(id) ?? [];
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
export async function loadRelations(executor, manifest, table, rows, withSpec) {
|
|
133
|
+
if (!withSpec || rows.length === 0)
|
|
134
|
+
return rows;
|
|
135
|
+
for (const [relationName, spec] of Object.entries(withSpec)) {
|
|
136
|
+
await loadOneRelation(executor, manifest, table, rows, relationName, spec);
|
|
137
|
+
}
|
|
138
|
+
return rows;
|
|
139
|
+
}
|
|
140
|
+
export async function findMany(executor, manifest, tableAccessor, args) {
|
|
141
|
+
const table = manifest.tables[tableAccessor];
|
|
142
|
+
if (!table)
|
|
143
|
+
throw new Error(`Unknown table: ${tableAccessor}`);
|
|
144
|
+
const { sql: whereSql, params } = compileWhere(table, args?.where, postgresDialect);
|
|
145
|
+
const orderSql = compileOrderBy(table, args?.orderBy);
|
|
146
|
+
const query = buildFindManyQuery(table, whereSql, orderSql, args?.limit, args?.offset);
|
|
147
|
+
const rows = await executor.query(query, params);
|
|
148
|
+
const mapped = rowsToTs(table, rows);
|
|
149
|
+
return loadRelations(executor, manifest, table, mapped, args?.with);
|
|
150
|
+
}
|
|
151
|
+
export async function findFirst(executor, manifest, tableAccessor, args) {
|
|
152
|
+
const rows = await findMany(executor, manifest, tableAccessor, {
|
|
153
|
+
...args,
|
|
154
|
+
limit: 1,
|
|
155
|
+
});
|
|
156
|
+
return rows[0] ?? null;
|
|
157
|
+
}
|
|
158
|
+
export async function findById(executor, manifest, tableAccessor, id, args) {
|
|
159
|
+
const table = manifest.tables[tableAccessor];
|
|
160
|
+
if (!table)
|
|
161
|
+
throw new Error(`Unknown table: ${tableAccessor}`);
|
|
162
|
+
const findArgs = {
|
|
163
|
+
where: { id },
|
|
164
|
+
limit: 1,
|
|
165
|
+
};
|
|
166
|
+
if (args?.with !== undefined) {
|
|
167
|
+
findArgs.with = args.with;
|
|
168
|
+
}
|
|
169
|
+
const rows = await findMany(executor, manifest, tableAccessor, findArgs);
|
|
170
|
+
return rows[0] ?? null;
|
|
171
|
+
}
|
|
172
|
+
//# sourceMappingURL=find.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find.js","sourceRoot":"","sources":["../../../src/runtime/query/find.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { Manifest } from "../../dialect/types.js";
|
|
2
|
+
import type { Executor } from "../executor.js";
|
|
3
|
+
import { type WithInput } from "./find.js";
|
|
4
|
+
export declare function updateRecord(executor: Executor, manifest: Manifest, tableAccessor: string, args: {
|
|
5
|
+
where: Record<string, unknown>;
|
|
6
|
+
data: Record<string, unknown>;
|
|
7
|
+
with?: Record<string, WithInput>;
|
|
8
|
+
}): Promise<Record<string, unknown> | null>;
|
|
9
|
+
export declare function updateManyRecords(executor: Executor, manifest: Manifest, tableAccessor: string, args: {
|
|
10
|
+
where?: Record<string, unknown>;
|
|
11
|
+
data: Record<string, unknown>;
|
|
12
|
+
}): Promise<number>;
|
|
13
|
+
export declare function updateById(executor: Executor, manifest: Manifest, tableAccessor: string, id: string, args: {
|
|
14
|
+
data: Record<string, unknown>;
|
|
15
|
+
with?: Record<string, WithInput>;
|
|
16
|
+
}): Promise<Record<string, unknown> | null>;
|
|
17
|
+
//# sourceMappingURL=update.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/update.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAS/C,OAAO,EAAiB,KAAK,SAAS,EAAE,MAAM,WAAW,CAAC;AAE1D,wBAAsB,YAAY,CAChC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,EAAE;IACJ,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAgDzC;AAED,wBAAsB,iBAAiB,CACrC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,IAAI,EAAE;IACJ,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC/B,GACA,OAAO,CAAC,MAAM,CAAC,CAkBjB;AAED,wBAAsB,UAAU,CAC9B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,MAAM,EACrB,EAAE,EAAE,MAAM,EACV,IAAI,EAAE;IACJ,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CAClC,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAMzC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { postgresDialect } from "../../dialect/postgres.js";
|
|
2
|
+
import { buildUpdateQuery, buildUpdateManyQuery, compileWhere, dataToSqlValues, rowToTs, } from "./compile.js";
|
|
3
|
+
import { loadRelations } from "./find.js";
|
|
4
|
+
export async function updateRecord(executor, manifest, tableAccessor, args) {
|
|
5
|
+
const table = manifest.tables[tableAccessor];
|
|
6
|
+
if (!table)
|
|
7
|
+
throw new Error(`Unknown table: ${tableAccessor}`);
|
|
8
|
+
const scalarData = {};
|
|
9
|
+
for (const [key, value] of Object.entries(args.data)) {
|
|
10
|
+
const col = table.columns.find((c) => c.tsName === key);
|
|
11
|
+
if (col) {
|
|
12
|
+
scalarData[key] = value;
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
const rel = table.relations.find((r) => r.name === key);
|
|
16
|
+
if (rel && value && typeof value === "object" && "connect" in value) {
|
|
17
|
+
const connect = value.connect;
|
|
18
|
+
if (rel.cardinality === "one") {
|
|
19
|
+
scalarData[rel.fkColumn] = connect.id;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
const { keys, values } = dataToSqlValues(table, scalarData);
|
|
25
|
+
if (keys.length === 0) {
|
|
26
|
+
throw new Error("Update requires at least one scalar field");
|
|
27
|
+
}
|
|
28
|
+
const { sql: whereSql, params: whereParams } = compileWhere(table, args.where, postgresDialect);
|
|
29
|
+
if (!whereSql) {
|
|
30
|
+
throw new Error("Update requires a where clause");
|
|
31
|
+
}
|
|
32
|
+
const query = buildUpdateQuery(table, keys, whereSql);
|
|
33
|
+
const row = await executor.queryOne(query, [...values, ...whereParams]);
|
|
34
|
+
if (!row)
|
|
35
|
+
return null;
|
|
36
|
+
const result = rowToTs(table, row);
|
|
37
|
+
if (args.with) {
|
|
38
|
+
const [withLoaded] = await loadRelations(executor, manifest, table, [result], args.with);
|
|
39
|
+
return withLoaded ?? result;
|
|
40
|
+
}
|
|
41
|
+
return result;
|
|
42
|
+
}
|
|
43
|
+
export async function updateManyRecords(executor, manifest, tableAccessor, args) {
|
|
44
|
+
const table = manifest.tables[tableAccessor];
|
|
45
|
+
if (!table)
|
|
46
|
+
throw new Error(`Unknown table: ${tableAccessor}`);
|
|
47
|
+
const { keys, values } = dataToSqlValues(table, args.data);
|
|
48
|
+
if (keys.length === 0) {
|
|
49
|
+
throw new Error("Update requires at least one scalar field");
|
|
50
|
+
}
|
|
51
|
+
const { sql: whereSql, params: whereParams } = compileWhere(table, args.where, postgresDialect);
|
|
52
|
+
const query = buildUpdateManyQuery(table, keys, whereSql);
|
|
53
|
+
const result = await executor.query(`${query} RETURNING id`, [...values, ...whereParams]);
|
|
54
|
+
return result.length;
|
|
55
|
+
}
|
|
56
|
+
export async function updateById(executor, manifest, tableAccessor, id, args) {
|
|
57
|
+
return updateRecord(executor, manifest, tableAccessor, {
|
|
58
|
+
where: { id },
|
|
59
|
+
data: args.data,
|
|
60
|
+
...(args.with !== undefined ? { with: args.with } : {}),
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=update.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.js","sourceRoot":"","sources":["../../../src/runtime/query/update.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import type { TableDef } from "../schema/table.js";
|
|
2
|
+
import type { CreateArgs, DeleteArgs, DeleteManyArgs, FindManyArgs, InferSelectRow, UpdateArgs, UpdateInput, UpdateManyArgs, WithInputMap } from "../schema/types.js";
|
|
3
|
+
/** Query args with an explicit generated `with` type (better IDE autocomplete) */
|
|
4
|
+
export type FindManyArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<FindManyArgs<TSchema, TAccessor>, "with"> & {
|
|
5
|
+
with?: TWith;
|
|
6
|
+
};
|
|
7
|
+
export type FindFirstArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = FindManyArgsWith<TSchema, TAccessor, TWith>;
|
|
8
|
+
export type FindByIdArgsWith<TWith> = {
|
|
9
|
+
with?: TWith;
|
|
10
|
+
};
|
|
11
|
+
export type CreateArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<CreateArgs<TSchema, TAccessor>, "with"> & {
|
|
12
|
+
with?: TWith;
|
|
13
|
+
};
|
|
14
|
+
export type UpdateArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<UpdateArgs<TSchema, TAccessor>, "with"> & {
|
|
15
|
+
with?: TWith;
|
|
16
|
+
};
|
|
17
|
+
export type DeleteArgsWith<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith> = Omit<DeleteArgs<TSchema, TAccessor>, "with"> & {
|
|
18
|
+
with?: TWith;
|
|
19
|
+
};
|
|
20
|
+
export type DefaultWithMap<TTables extends Record<string, TableDef>> = {
|
|
21
|
+
[K in keyof TTables & string]: WithInputMap<TTables, K>;
|
|
22
|
+
};
|
|
23
|
+
export type TypedTableRepository<TSchema extends Record<string, TableDef>, TAccessor extends keyof TSchema & string, TWith = WithInputMap<TSchema, TAccessor>> = {
|
|
24
|
+
findMany(args?: FindManyArgsWith<TSchema, TAccessor, TWith>): Promise<Array<InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>>>;
|
|
25
|
+
findFirst(args?: FindFirstArgsWith<TSchema, TAccessor, TWith>): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
|
|
26
|
+
findById(id: string, args?: FindByIdArgsWith<TWith>): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
|
|
27
|
+
create(args: CreateArgsWith<TSchema, TAccessor, TWith>): Promise<InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>>;
|
|
28
|
+
update(args: UpdateArgsWith<TSchema, TAccessor, TWith>): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
|
|
29
|
+
updateMany(args: UpdateManyArgs<TSchema, TAccessor>): Promise<number>;
|
|
30
|
+
updateById(id: string, args: {
|
|
31
|
+
data: UpdateInput<TSchema[TAccessor]["_columns"]>;
|
|
32
|
+
with?: TWith;
|
|
33
|
+
}): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
|
|
34
|
+
delete(args: DeleteArgsWith<TSchema, TAccessor, TWith>): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
|
|
35
|
+
deleteMany(args?: DeleteManyArgs<TSchema, TAccessor>): Promise<number>;
|
|
36
|
+
deleteById(id: string): Promise<(InferSelectRow<TSchema[TAccessor]["_columns"]> & Record<string, unknown>) | null>;
|
|
37
|
+
};
|
|
38
|
+
export type TypedNeoOrmClient<TTables extends Record<string, TableDef>, TIncludes extends Record<keyof TTables & string, unknown> = DefaultWithMap<TTables>> = {
|
|
39
|
+
sql<T = Record<string, unknown>>(strings: TemplateStringsArray, ...values: unknown[]): Promise<T[]>;
|
|
40
|
+
execute(query: {
|
|
41
|
+
text: string;
|
|
42
|
+
params: unknown[];
|
|
43
|
+
}): Promise<Record<string, unknown>[]>;
|
|
44
|
+
$disconnect(): Promise<void>;
|
|
45
|
+
} & {
|
|
46
|
+
[K in keyof TTables & string]: TypedTableRepository<TTables, K, TIncludes[K]>;
|
|
47
|
+
};
|
|
48
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/runtime/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/runtime/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
export type ColumnKind = "id" | "text" | "bool" | "int" | "timestamp" | "fk";
|
|
2
|
+
export type ColumnMeta = {
|
|
3
|
+
kind: ColumnKind;
|
|
4
|
+
nullable: boolean;
|
|
5
|
+
unique: boolean;
|
|
6
|
+
primary: boolean;
|
|
7
|
+
defaultValue?: unknown;
|
|
8
|
+
defaultNow: boolean;
|
|
9
|
+
};
|
|
10
|
+
export type ColumnBuilder<TValue, TMeta extends ColumnMeta = ColumnMeta> = {
|
|
11
|
+
readonly _type: TValue;
|
|
12
|
+
readonly _meta: TMeta;
|
|
13
|
+
notNull(): ColumnBuilder<TValue, Omit<TMeta, "nullable"> & {
|
|
14
|
+
nullable: false;
|
|
15
|
+
}>;
|
|
16
|
+
unique(): ColumnBuilder<TValue, Omit<TMeta, "unique"> & {
|
|
17
|
+
unique: true;
|
|
18
|
+
}>;
|
|
19
|
+
default(value: TValue): ColumnBuilder<TValue, Omit<TMeta, "defaultValue"> & {
|
|
20
|
+
defaultValue: TValue;
|
|
21
|
+
}>;
|
|
22
|
+
defaultNow(): ColumnBuilder<TValue, Omit<TMeta, "defaultNow"> & {
|
|
23
|
+
defaultNow: true;
|
|
24
|
+
}>;
|
|
25
|
+
primary(): ColumnBuilder<TValue, Omit<TMeta, "primary"> & {
|
|
26
|
+
primary: true;
|
|
27
|
+
}>;
|
|
28
|
+
};
|
|
29
|
+
export declare const id: {
|
|
30
|
+
primary(): ColumnBuilder<string, ColumnMeta & {
|
|
31
|
+
primary: true;
|
|
32
|
+
nullable: false;
|
|
33
|
+
}>;
|
|
34
|
+
};
|
|
35
|
+
export declare function text(): ColumnBuilder<string | null>;
|
|
36
|
+
export declare function bool(): ColumnBuilder<boolean | null>;
|
|
37
|
+
export declare function int(): ColumnBuilder<number | null>;
|
|
38
|
+
export declare function timestamp(): ColumnBuilder<Date | null>;
|
|
39
|
+
//# sourceMappingURL=column.d.ts.map
|