Initial commit - Event Planner application
This commit is contained in:
212
node_modules/kysely/dist/esm/helpers/mssql.d.ts
generated
vendored
Normal file
212
node_modules/kysely/dist/esm/helpers/mssql.d.ts
generated
vendored
Normal file
@@ -0,0 +1,212 @@
|
||||
import type { Expression } from '../expression/expression.js';
|
||||
import type { RawBuilder } from '../raw-builder/raw-builder.js';
|
||||
import type { ShallowDehydrateObject, ShallowDehydrateValue, Simplify } from '../util/type-utils.js';
|
||||
/**
|
||||
* An MS SQL Server helper for aggregating a subquery into a JSON array.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import { Kysely, MssqlDialect, ParseJSONResultsPlugin } from 'kysely'
|
||||
* import * as Tarn from 'tarn'
|
||||
* import * as Tedious from 'tedious'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new MssqlDialect({
|
||||
* tarn: { options: { max: 10, min: 0 }, ...Tarn },
|
||||
* tedious: {
|
||||
* ...Tedious,
|
||||
* connectionFactory: () => new Tedious.Connection({
|
||||
* authentication: {
|
||||
* options: { password: 'password', userName: 'sa' },
|
||||
* type: 'default',
|
||||
* },
|
||||
* options: { database: 'test', port: 21433, trustServerCertificate: true },
|
||||
* server: 'localhost',
|
||||
* }),
|
||||
* },
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonArrayFrom } from 'kysely/helpers/mssql'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonArrayFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .orderBy('pet.name')
|
||||
* .offset(0)
|
||||
* ).as('pets')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.pets[0]?.pet_id
|
||||
* result[0]?.pets[0]?.name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MS SQL Server):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select coalesce((select * from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* order by "pet"."name"
|
||||
* offset @1 rows
|
||||
* ) as "agg" for json path, include_null_values), '[]')
|
||||
* ) as "pets"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonArrayFrom<O>(expr: Expression<O>): RawBuilder<Simplify<ShallowDehydrateObject<O>>[]>;
|
||||
/**
|
||||
* An MS SQL Server helper for turning a subquery into a JSON object.
|
||||
*
|
||||
* The subquery must only return one row.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import { Kysely, MssqlDialect, ParseJSONResultsPlugin } from 'kysely'
|
||||
* import * as Tarn from 'tarn'
|
||||
* import * as Tedious from 'tedious'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new MssqlDialect({
|
||||
* tarn: { options: { max: 10, min: 0 }, ...Tarn },
|
||||
* tedious: {
|
||||
* ...Tedious,
|
||||
* connectionFactory: () => new Tedious.Connection({
|
||||
* authentication: {
|
||||
* options: { password: 'password', userName: 'sa' },
|
||||
* type: 'default',
|
||||
* },
|
||||
* options: { database: 'test', port: 21433, trustServerCertificate: true },
|
||||
* server: 'localhost',
|
||||
* }),
|
||||
* },
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonObjectFrom } from 'kysely/helpers/mssql'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonObjectFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .where('pet.is_favorite', '=', 1)
|
||||
* ).as('favorite_pet')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.favorite_pet?.pet_id
|
||||
* result[0]?.favorite_pet?.name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MS SQL Server):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select * from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* and "pet"."is_favorite" = @1
|
||||
* ) as "agg" for json path, include_null_values, without_array_wrapper
|
||||
* ) as "favorite_pet"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonObjectFrom<O>(expr: Expression<O>): RawBuilder<Simplify<ShallowDehydrateObject<O>> | null>;
|
||||
/**
|
||||
* The MS SQL Server `json_query` function, single argument variant.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import { Kysely, MssqlDialect, ParseJSONResultsPlugin } from 'kysely'
|
||||
* import * as Tarn from 'tarn'
|
||||
* import * as Tedious from 'tedious'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new MssqlDialect({
|
||||
* tarn: { options: { max: 10, min: 0 }, ...Tarn },
|
||||
* tedious: {
|
||||
* ...Tedious,
|
||||
* connectionFactory: () => new Tedious.Connection({
|
||||
* authentication: {
|
||||
* options: { password: 'password', userName: 'sa' },
|
||||
* type: 'default',
|
||||
* },
|
||||
* options: { database: 'test', port: 21433, trustServerCertificate: true },
|
||||
* server: 'localhost',
|
||||
* }),
|
||||
* },
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonBuildObject } from 'kysely/helpers/mssql'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonBuildObject({
|
||||
* first: eb.ref('first_name'),
|
||||
* last: eb.ref('last_name'),
|
||||
* full: eb.fn('concat', ['first_name', eb.val(' '), 'last_name'])
|
||||
* }).as('name')
|
||||
* ])
|
||||
* .execute()
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MS SQL Server):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", json_query(
|
||||
* '{"first":"'+"first_name"+',"last":"'+"last_name"+',"full":"'+concat("first_name", ' ', "last_name")+'"}'
|
||||
* ) as "name"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonBuildObject<O extends Record<string, Expression<unknown>>>(obj: O): RawBuilder<Simplify<{
|
||||
[K in keyof O]: O[K] extends Expression<infer V> ? ShallowDehydrateValue<V> : never;
|
||||
}>>;
|
||||
215
node_modules/kysely/dist/esm/helpers/mssql.js
generated
vendored
Normal file
215
node_modules/kysely/dist/esm/helpers/mssql.js
generated
vendored
Normal file
@@ -0,0 +1,215 @@
|
||||
/// <reference types="./mssql.d.ts" />
|
||||
import { sql } from '../raw-builder/sql.js';
|
||||
/**
|
||||
* An MS SQL Server helper for aggregating a subquery into a JSON array.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import { Kysely, MssqlDialect, ParseJSONResultsPlugin } from 'kysely'
|
||||
* import * as Tarn from 'tarn'
|
||||
* import * as Tedious from 'tedious'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new MssqlDialect({
|
||||
* tarn: { options: { max: 10, min: 0 }, ...Tarn },
|
||||
* tedious: {
|
||||
* ...Tedious,
|
||||
* connectionFactory: () => new Tedious.Connection({
|
||||
* authentication: {
|
||||
* options: { password: 'password', userName: 'sa' },
|
||||
* type: 'default',
|
||||
* },
|
||||
* options: { database: 'test', port: 21433, trustServerCertificate: true },
|
||||
* server: 'localhost',
|
||||
* }),
|
||||
* },
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonArrayFrom } from 'kysely/helpers/mssql'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonArrayFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .orderBy('pet.name')
|
||||
* .offset(0)
|
||||
* ).as('pets')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.pets[0]?.pet_id
|
||||
* result[0]?.pets[0]?.name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MS SQL Server):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select coalesce((select * from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* order by "pet"."name"
|
||||
* offset @1 rows
|
||||
* ) as "agg" for json path, include_null_values), '[]')
|
||||
* ) as "pets"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export function jsonArrayFrom(expr) {
|
||||
return sql `coalesce((select * from ${expr} as agg for json path, include_null_values), '[]')`;
|
||||
}
|
||||
/**
|
||||
* An MS SQL Server helper for turning a subquery into a JSON object.
|
||||
*
|
||||
* The subquery must only return one row.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import { Kysely, MssqlDialect, ParseJSONResultsPlugin } from 'kysely'
|
||||
* import * as Tarn from 'tarn'
|
||||
* import * as Tedious from 'tedious'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new MssqlDialect({
|
||||
* tarn: { options: { max: 10, min: 0 }, ...Tarn },
|
||||
* tedious: {
|
||||
* ...Tedious,
|
||||
* connectionFactory: () => new Tedious.Connection({
|
||||
* authentication: {
|
||||
* options: { password: 'password', userName: 'sa' },
|
||||
* type: 'default',
|
||||
* },
|
||||
* options: { database: 'test', port: 21433, trustServerCertificate: true },
|
||||
* server: 'localhost',
|
||||
* }),
|
||||
* },
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonObjectFrom } from 'kysely/helpers/mssql'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonObjectFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .where('pet.is_favorite', '=', 1)
|
||||
* ).as('favorite_pet')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.favorite_pet?.pet_id
|
||||
* result[0]?.favorite_pet?.name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MS SQL Server):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select * from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* and "pet"."is_favorite" = @1
|
||||
* ) as "agg" for json path, include_null_values, without_array_wrapper
|
||||
* ) as "favorite_pet"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export function jsonObjectFrom(expr) {
|
||||
return sql `(select * from ${expr} as agg for json path, include_null_values, without_array_wrapper)`;
|
||||
}
|
||||
/**
|
||||
* The MS SQL Server `json_query` function, single argument variant.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import { Kysely, MssqlDialect, ParseJSONResultsPlugin } from 'kysely'
|
||||
* import * as Tarn from 'tarn'
|
||||
* import * as Tedious from 'tedious'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new MssqlDialect({
|
||||
* tarn: { options: { max: 10, min: 0 }, ...Tarn },
|
||||
* tedious: {
|
||||
* ...Tedious,
|
||||
* connectionFactory: () => new Tedious.Connection({
|
||||
* authentication: {
|
||||
* options: { password: 'password', userName: 'sa' },
|
||||
* type: 'default',
|
||||
* },
|
||||
* options: { database: 'test', port: 21433, trustServerCertificate: true },
|
||||
* server: 'localhost',
|
||||
* }),
|
||||
* },
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonBuildObject } from 'kysely/helpers/mssql'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonBuildObject({
|
||||
* first: eb.ref('first_name'),
|
||||
* last: eb.ref('last_name'),
|
||||
* full: eb.fn('concat', ['first_name', eb.val(' '), 'last_name'])
|
||||
* }).as('name')
|
||||
* ])
|
||||
* .execute()
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MS SQL Server):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", json_query(
|
||||
* '{"first":"'+"first_name"+',"last":"'+"last_name"+',"full":"'+concat("first_name", ' ', "last_name")+'"}'
|
||||
* ) as "name"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export function jsonBuildObject(obj) {
|
||||
return sql `json_query('{${sql.join(Object.keys(obj).map((k) => sql `"${sql.raw(k)}":"'+${obj[k]}+'"`), sql `,`)}}')`;
|
||||
}
|
||||
147
node_modules/kysely/dist/esm/helpers/mysql.d.ts
generated
vendored
Normal file
147
node_modules/kysely/dist/esm/helpers/mysql.d.ts
generated
vendored
Normal file
@@ -0,0 +1,147 @@
|
||||
import type { Expression } from '../expression/expression.js';
|
||||
import type { SelectQueryBuilderExpression } from '../query-builder/select-query-builder-expression.js';
|
||||
import type { RawBuilder } from '../raw-builder/raw-builder.js';
|
||||
import type { ShallowDehydrateObject, ShallowDehydrateValue, Simplify } from '../util/type-utils.js';
|
||||
/**
|
||||
* A MySQL helper for aggregating a subquery into a JSON array.
|
||||
*
|
||||
* NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.
|
||||
* While the produced SQL is compatible with all MySQL databases, some third-party dialects
|
||||
* may not parse the nested JSON into arrays. In these cases you can use the built in
|
||||
* `ParseJSONResultsPlugin` to parse the results.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonArrayFrom } from 'kysely/helpers/mysql'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonArrayFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .orderBy('pet.name')
|
||||
* ).as('pets')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.pets[0]?.pet_id
|
||||
* result[0]?.pets[0]?.name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MySQL):
|
||||
*
|
||||
* ```sql
|
||||
* select `id`, (
|
||||
* select cast(coalesce(json_arrayagg(json_object(
|
||||
* 'pet_id', `agg`.`pet_id`,
|
||||
* 'name', `agg`.`name`
|
||||
* )), '[]') as json) from (
|
||||
* select `pet`.`id` as `pet_id`, `pet`.`name`
|
||||
* from `pet`
|
||||
* where `pet`.`owner_id` = `person`.`id`
|
||||
* order by `pet`.`name`
|
||||
* ) as `agg`
|
||||
* ) as `pets`
|
||||
* from `person`
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonArrayFrom<O>(expr: SelectQueryBuilderExpression<O>): RawBuilder<Simplify<ShallowDehydrateObject<O>>[]>;
|
||||
/**
|
||||
* A MySQL helper for turning a subquery into a JSON object.
|
||||
*
|
||||
* The subquery must only return one row.
|
||||
*
|
||||
* NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.
|
||||
* While the produced SQL is compatible with all MySQL databases, some third-party dialects
|
||||
* may not parse the nested JSON into objects. In these cases you can use the built in
|
||||
* `ParseJSONResultsPlugin` to parse the results.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonObjectFrom } from 'kysely/helpers/mysql'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonObjectFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .where('pet.is_favorite', '=', true)
|
||||
* ).as('favorite_pet')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.favorite_pet?.pet_id
|
||||
* result[0]?.favorite_pet?.name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MySQL):
|
||||
*
|
||||
* ```sql
|
||||
* select `id`, (
|
||||
* select json_object(
|
||||
* 'pet_id', `obj`.`pet_id`,
|
||||
* 'name', `obj`.`name`
|
||||
* ) from (
|
||||
* select `pet`.`id` as `pet_id`, `pet`.`name`
|
||||
* from `pet`
|
||||
* where `pet`.`owner_id` = `person`.`id`
|
||||
* and `pet`.`is_favorite` = ?
|
||||
* ) as obj
|
||||
* ) as `favorite_pet`
|
||||
* from `person`
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonObjectFrom<O>(expr: SelectQueryBuilderExpression<O>): RawBuilder<Simplify<ShallowDehydrateObject<O>> | null>;
|
||||
/**
|
||||
* The MySQL `json_object` function.
|
||||
*
|
||||
* NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.
|
||||
* While the produced SQL is compatible with all MySQL databases, some third-party dialects
|
||||
* may not parse the nested JSON into objects. In these cases you can use the built in
|
||||
* `ParseJSONResultsPlugin` to parse the results.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonBuildObject({
|
||||
* first: eb.ref('first_name'),
|
||||
* last: eb.ref('last_name'),
|
||||
* full: eb.fn('concat', ['first_name', eb.val(' '), 'last_name'])
|
||||
* }).as('name')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.name.first
|
||||
* result[0]?.name.last
|
||||
* result[0]?.name.full
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MySQL):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", json_object(
|
||||
* 'first', first_name,
|
||||
* 'last', last_name,
|
||||
* 'full', concat(`first_name`, ?, `last_name`)
|
||||
* ) as "name"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonBuildObject<O extends Record<string, Expression<unknown>>>(obj: O): RawBuilder<Simplify<{
|
||||
[K in keyof O]: O[K] extends Expression<infer V> ? ShallowDehydrateValue<V> : never;
|
||||
}>>;
|
||||
158
node_modules/kysely/dist/esm/helpers/mysql.js
generated
vendored
Normal file
158
node_modules/kysely/dist/esm/helpers/mysql.js
generated
vendored
Normal file
@@ -0,0 +1,158 @@
|
||||
/// <reference types="./mysql.d.ts" />
|
||||
import { sql } from '../raw-builder/sql.js';
|
||||
import { getJsonObjectArgs } from '../util/json-object-args.js';
|
||||
/**
|
||||
* A MySQL helper for aggregating a subquery into a JSON array.
|
||||
*
|
||||
* NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.
|
||||
* While the produced SQL is compatible with all MySQL databases, some third-party dialects
|
||||
* may not parse the nested JSON into arrays. In these cases you can use the built in
|
||||
* `ParseJSONResultsPlugin` to parse the results.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonArrayFrom } from 'kysely/helpers/mysql'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonArrayFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .orderBy('pet.name')
|
||||
* ).as('pets')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.pets[0]?.pet_id
|
||||
* result[0]?.pets[0]?.name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MySQL):
|
||||
*
|
||||
* ```sql
|
||||
* select `id`, (
|
||||
* select cast(coalesce(json_arrayagg(json_object(
|
||||
* 'pet_id', `agg`.`pet_id`,
|
||||
* 'name', `agg`.`name`
|
||||
* )), '[]') as json) from (
|
||||
* select `pet`.`id` as `pet_id`, `pet`.`name`
|
||||
* from `pet`
|
||||
* where `pet`.`owner_id` = `person`.`id`
|
||||
* order by `pet`.`name`
|
||||
* ) as `agg`
|
||||
* ) as `pets`
|
||||
* from `person`
|
||||
* ```
|
||||
*/
|
||||
export function jsonArrayFrom(expr) {
|
||||
return sql `(select cast(coalesce(json_arrayagg(json_object(${sql.join(getMysqlJsonObjectArgs(expr.toOperationNode(), 'agg'))})), '[]') as json) from ${expr} as agg)`;
|
||||
}
|
||||
/**
|
||||
* A MySQL helper for turning a subquery into a JSON object.
|
||||
*
|
||||
* The subquery must only return one row.
|
||||
*
|
||||
* NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.
|
||||
* While the produced SQL is compatible with all MySQL databases, some third-party dialects
|
||||
* may not parse the nested JSON into objects. In these cases you can use the built in
|
||||
* `ParseJSONResultsPlugin` to parse the results.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonObjectFrom } from 'kysely/helpers/mysql'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonObjectFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .where('pet.is_favorite', '=', true)
|
||||
* ).as('favorite_pet')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.favorite_pet?.pet_id
|
||||
* result[0]?.favorite_pet?.name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MySQL):
|
||||
*
|
||||
* ```sql
|
||||
* select `id`, (
|
||||
* select json_object(
|
||||
* 'pet_id', `obj`.`pet_id`,
|
||||
* 'name', `obj`.`name`
|
||||
* ) from (
|
||||
* select `pet`.`id` as `pet_id`, `pet`.`name`
|
||||
* from `pet`
|
||||
* where `pet`.`owner_id` = `person`.`id`
|
||||
* and `pet`.`is_favorite` = ?
|
||||
* ) as obj
|
||||
* ) as `favorite_pet`
|
||||
* from `person`
|
||||
* ```
|
||||
*/
|
||||
export function jsonObjectFrom(expr) {
|
||||
return sql `(select json_object(${sql.join(getMysqlJsonObjectArgs(expr.toOperationNode(), 'obj'))}) from ${expr} as obj)`;
|
||||
}
|
||||
/**
|
||||
* The MySQL `json_object` function.
|
||||
*
|
||||
* NOTE: This helper is only guaranteed to fully work with the built-in `MysqlDialect`.
|
||||
* While the produced SQL is compatible with all MySQL databases, some third-party dialects
|
||||
* may not parse the nested JSON into objects. In these cases you can use the built in
|
||||
* `ParseJSONResultsPlugin` to parse the results.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonBuildObject({
|
||||
* first: eb.ref('first_name'),
|
||||
* last: eb.ref('last_name'),
|
||||
* full: eb.fn('concat', ['first_name', eb.val(' '), 'last_name'])
|
||||
* }).as('name')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.name.first
|
||||
* result[0]?.name.last
|
||||
* result[0]?.name.full
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (MySQL):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", json_object(
|
||||
* 'first', first_name,
|
||||
* 'last', last_name,
|
||||
* 'full', concat(`first_name`, ?, `last_name`)
|
||||
* ) as "name"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export function jsonBuildObject(obj) {
|
||||
return sql `json_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;
|
||||
}
|
||||
function getMysqlJsonObjectArgs(node, table) {
|
||||
try {
|
||||
return getJsonObjectArgs(node, table);
|
||||
}
|
||||
catch {
|
||||
throw new Error('MySQL jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.');
|
||||
}
|
||||
}
|
||||
199
node_modules/kysely/dist/esm/helpers/postgres.d.ts
generated
vendored
Normal file
199
node_modules/kysely/dist/esm/helpers/postgres.d.ts
generated
vendored
Normal file
@@ -0,0 +1,199 @@
|
||||
import type { Expression } from '../expression/expression.js';
|
||||
import type { RawBuilder } from '../raw-builder/raw-builder.js';
|
||||
import type { ShallowDehydrateValue, ShallowDehydrateObject, Simplify } from '../util/type-utils.js';
|
||||
/**
|
||||
* A postgres helper for aggregating a subquery (or other expression) into a JSONB array.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* <!-- siteExample("select", "Nested array", 110) -->
|
||||
*
|
||||
* While kysely is not an ORM and it doesn't have the concept of relations, we do provide
|
||||
* helpers for fetching nested objects and arrays in a single query. In this example we
|
||||
* use the `jsonArrayFrom` helper to fetch person's pets along with the person's id.
|
||||
*
|
||||
* Please keep in mind that the helpers under the `kysely/helpers` folder, including
|
||||
* `jsonArrayFrom`, are not guaranteed to work with third party dialects. In order for
|
||||
* them to work, the dialect must automatically parse the `json` data type into
|
||||
* JavaScript JSON values like objects and arrays. Some dialects might simply return
|
||||
* the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`
|
||||
* to parse the results.
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonArrayFrom } from 'kysely/helpers/postgres'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonArrayFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .orderBy('pet.name')
|
||||
* ).as('pets')
|
||||
* ])
|
||||
* .execute()
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (PostgreSQL):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select coalesce(json_agg(agg), '[]') from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* order by "pet"."name"
|
||||
* ) as agg
|
||||
* ) as "pets"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonArrayFrom<O>(expr: Expression<O>): RawBuilder<Simplify<ShallowDehydrateObject<O>>[]>;
|
||||
/**
|
||||
* A postgres helper for turning a subquery (or other expression) into a JSON object.
|
||||
*
|
||||
* The subquery must only return one row.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* <!-- siteExample("select", "Nested object", 120) -->
|
||||
*
|
||||
* While kysely is not an ORM and it doesn't have the concept of relations, we do provide
|
||||
* helpers for fetching nested objects and arrays in a single query. In this example we
|
||||
* use the `jsonObjectFrom` helper to fetch person's favorite pet along with the person's id.
|
||||
*
|
||||
* Please keep in mind that the helpers under the `kysely/helpers` folder, including
|
||||
* `jsonObjectFrom`, are not guaranteed to work with third-party dialects. In order for
|
||||
* them to work, the dialect must automatically parse the `json` data type into
|
||||
* JavaScript JSON values like objects and arrays. Some dialects might simply return
|
||||
* the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`
|
||||
* to parse the results.
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonObjectFrom } from 'kysely/helpers/postgres'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonObjectFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .where('pet.is_favorite', '=', true)
|
||||
* ).as('favorite_pet')
|
||||
* ])
|
||||
* .execute()
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (PostgreSQL):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select to_json(obj) from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* and "pet"."is_favorite" = $1
|
||||
* ) as obj
|
||||
* ) as "favorite_pet"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonObjectFrom<O>(expr: Expression<O>): RawBuilder<Simplify<ShallowDehydrateObject<O>> | null>;
|
||||
/**
|
||||
* The PostgreSQL `json_build_object` function.
|
||||
*
|
||||
* NOTE: This helper is only guaranteed to fully work with the built-in `PostgresDialect`.
|
||||
* While the produced SQL is compatible with all PostgreSQL databases, some third-party dialects
|
||||
* may not parse the nested JSON into objects. In these cases you can use the built in
|
||||
* `ParseJSONResultsPlugin` to parse the results.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { sql } from 'kysely'
|
||||
* import { jsonBuildObject } from 'kysely/helpers/postgres'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonBuildObject({
|
||||
* first: eb.ref('first_name'),
|
||||
* last: eb.ref('last_name'),
|
||||
* full: sql<string>`first_name || ' ' || last_name`
|
||||
* }).as('name')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.name.first
|
||||
* result[0]?.name.last
|
||||
* result[0]?.name.full
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (PostgreSQL):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", json_build_object(
|
||||
* 'first', first_name,
|
||||
* 'last', last_name,
|
||||
* 'full', first_name || ' ' || last_name
|
||||
* ) as "name"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonBuildObject<O extends Record<string, Expression<unknown>>>(obj: O): RawBuilder<Simplify<{
|
||||
[K in keyof O]: O[K] extends Expression<infer V> ? ShallowDehydrateValue<V> : never;
|
||||
}>>;
|
||||
export type MergeAction = 'INSERT' | 'UPDATE' | 'DELETE';
|
||||
/**
|
||||
* The PostgreSQL `merge_action` function.
|
||||
*
|
||||
* This function can be used in a `returning` clause to get the action that was
|
||||
* performed in a `mergeInto` query. The function returns one of the following
|
||||
* strings: `'INSERT'`, `'UPDATE'`, or `'DELETE'`.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { mergeAction } from 'kysely/helpers/postgres'
|
||||
*
|
||||
* const result = await db
|
||||
* .mergeInto('person as p')
|
||||
* .using('person_backup as pb', 'p.id', 'pb.id')
|
||||
* .whenMatched()
|
||||
* .thenUpdateSet(({ ref }) => ({
|
||||
* first_name: ref('pb.first_name'),
|
||||
* updated_at: ref('pb.updated_at').$castTo<string | null>(),
|
||||
* }))
|
||||
* .whenNotMatched()
|
||||
* .thenInsertValues(({ ref}) => ({
|
||||
* id: ref('pb.id'),
|
||||
* first_name: ref('pb.first_name'),
|
||||
* created_at: ref('pb.updated_at'),
|
||||
* updated_at: ref('pb.updated_at').$castTo<string | null>(),
|
||||
* }))
|
||||
* .returning([mergeAction().as('action'), 'p.id', 'p.updated_at'])
|
||||
* .execute()
|
||||
*
|
||||
* result[0].action
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (PostgreSQL):
|
||||
*
|
||||
* ```sql
|
||||
* merge into "person" as "p"
|
||||
* using "person_backup" as "pb" on "p"."id" = "pb"."id"
|
||||
* when matched then update set
|
||||
* "first_name" = "pb"."first_name",
|
||||
* "updated_at" = "pb"."updated_at"::text
|
||||
* when not matched then insert values ("id", "first_name", "created_at", "updated_at")
|
||||
* values ("pb"."id", "pb"."first_name", "pb"."updated_at", "pb"."updated_at")
|
||||
* returning merge_action() as "action", "p"."id", "p"."updated_at"
|
||||
* ```
|
||||
*/
|
||||
export declare function mergeAction(): RawBuilder<MergeAction>;
|
||||
203
node_modules/kysely/dist/esm/helpers/postgres.js
generated
vendored
Normal file
203
node_modules/kysely/dist/esm/helpers/postgres.js
generated
vendored
Normal file
@@ -0,0 +1,203 @@
|
||||
/// <reference types="./postgres.d.ts" />
|
||||
import { sql } from '../raw-builder/sql.js';
|
||||
/**
|
||||
* A postgres helper for aggregating a subquery (or other expression) into a JSONB array.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* <!-- siteExample("select", "Nested array", 110) -->
|
||||
*
|
||||
* While kysely is not an ORM and it doesn't have the concept of relations, we do provide
|
||||
* helpers for fetching nested objects and arrays in a single query. In this example we
|
||||
* use the `jsonArrayFrom` helper to fetch person's pets along with the person's id.
|
||||
*
|
||||
* Please keep in mind that the helpers under the `kysely/helpers` folder, including
|
||||
* `jsonArrayFrom`, are not guaranteed to work with third party dialects. In order for
|
||||
* them to work, the dialect must automatically parse the `json` data type into
|
||||
* JavaScript JSON values like objects and arrays. Some dialects might simply return
|
||||
* the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`
|
||||
* to parse the results.
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonArrayFrom } from 'kysely/helpers/postgres'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonArrayFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .orderBy('pet.name')
|
||||
* ).as('pets')
|
||||
* ])
|
||||
* .execute()
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (PostgreSQL):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select coalesce(json_agg(agg), '[]') from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* order by "pet"."name"
|
||||
* ) as agg
|
||||
* ) as "pets"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export function jsonArrayFrom(expr) {
|
||||
return sql `(select coalesce(json_agg(agg), '[]') from ${expr} as agg)`;
|
||||
}
|
||||
/**
|
||||
* A postgres helper for turning a subquery (or other expression) into a JSON object.
|
||||
*
|
||||
* The subquery must only return one row.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* <!-- siteExample("select", "Nested object", 120) -->
|
||||
*
|
||||
* While kysely is not an ORM and it doesn't have the concept of relations, we do provide
|
||||
* helpers for fetching nested objects and arrays in a single query. In this example we
|
||||
* use the `jsonObjectFrom` helper to fetch person's favorite pet along with the person's id.
|
||||
*
|
||||
* Please keep in mind that the helpers under the `kysely/helpers` folder, including
|
||||
* `jsonObjectFrom`, are not guaranteed to work with third-party dialects. In order for
|
||||
* them to work, the dialect must automatically parse the `json` data type into
|
||||
* JavaScript JSON values like objects and arrays. Some dialects might simply return
|
||||
* the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`
|
||||
* to parse the results.
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonObjectFrom } from 'kysely/helpers/postgres'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonObjectFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .where('pet.is_favorite', '=', true)
|
||||
* ).as('favorite_pet')
|
||||
* ])
|
||||
* .execute()
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (PostgreSQL):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select to_json(obj) from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* and "pet"."is_favorite" = $1
|
||||
* ) as obj
|
||||
* ) as "favorite_pet"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export function jsonObjectFrom(expr) {
|
||||
return sql `(select to_json(obj) from ${expr} as obj)`;
|
||||
}
|
||||
/**
|
||||
* The PostgreSQL `json_build_object` function.
|
||||
*
|
||||
* NOTE: This helper is only guaranteed to fully work with the built-in `PostgresDialect`.
|
||||
* While the produced SQL is compatible with all PostgreSQL databases, some third-party dialects
|
||||
* may not parse the nested JSON into objects. In these cases you can use the built in
|
||||
* `ParseJSONResultsPlugin` to parse the results.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { sql } from 'kysely'
|
||||
* import { jsonBuildObject } from 'kysely/helpers/postgres'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonBuildObject({
|
||||
* first: eb.ref('first_name'),
|
||||
* last: eb.ref('last_name'),
|
||||
* full: sql<string>`first_name || ' ' || last_name`
|
||||
* }).as('name')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.name.first
|
||||
* result[0]?.name.last
|
||||
* result[0]?.name.full
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (PostgreSQL):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", json_build_object(
|
||||
* 'first', first_name,
|
||||
* 'last', last_name,
|
||||
* 'full', first_name || ' ' || last_name
|
||||
* ) as "name"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export function jsonBuildObject(obj) {
|
||||
return sql `json_build_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;
|
||||
}
|
||||
/**
|
||||
* The PostgreSQL `merge_action` function.
|
||||
*
|
||||
* This function can be used in a `returning` clause to get the action that was
|
||||
* performed in a `mergeInto` query. The function returns one of the following
|
||||
* strings: `'INSERT'`, `'UPDATE'`, or `'DELETE'`.
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { mergeAction } from 'kysely/helpers/postgres'
|
||||
*
|
||||
* const result = await db
|
||||
* .mergeInto('person as p')
|
||||
* .using('person_backup as pb', 'p.id', 'pb.id')
|
||||
* .whenMatched()
|
||||
* .thenUpdateSet(({ ref }) => ({
|
||||
* first_name: ref('pb.first_name'),
|
||||
* updated_at: ref('pb.updated_at').$castTo<string | null>(),
|
||||
* }))
|
||||
* .whenNotMatched()
|
||||
* .thenInsertValues(({ ref}) => ({
|
||||
* id: ref('pb.id'),
|
||||
* first_name: ref('pb.first_name'),
|
||||
* created_at: ref('pb.updated_at'),
|
||||
* updated_at: ref('pb.updated_at').$castTo<string | null>(),
|
||||
* }))
|
||||
* .returning([mergeAction().as('action'), 'p.id', 'p.updated_at'])
|
||||
* .execute()
|
||||
*
|
||||
* result[0].action
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (PostgreSQL):
|
||||
*
|
||||
* ```sql
|
||||
* merge into "person" as "p"
|
||||
* using "person_backup" as "pb" on "p"."id" = "pb"."id"
|
||||
* when matched then update set
|
||||
* "first_name" = "pb"."first_name",
|
||||
* "updated_at" = "pb"."updated_at"::text
|
||||
* when not matched then insert values ("id", "first_name", "created_at", "updated_at")
|
||||
* values ("pb"."id", "pb"."first_name", "pb"."updated_at", "pb"."updated_at")
|
||||
* returning merge_action() as "action", "p"."id", "p"."updated_at"
|
||||
* ```
|
||||
*/
|
||||
export function mergeAction() {
|
||||
return sql `merge_action()`;
|
||||
}
|
||||
189
node_modules/kysely/dist/esm/helpers/sqlite.d.ts
generated
vendored
Normal file
189
node_modules/kysely/dist/esm/helpers/sqlite.d.ts
generated
vendored
Normal file
@@ -0,0 +1,189 @@
|
||||
import type { Expression } from '../expression/expression.js';
|
||||
import type { SelectQueryBuilderExpression } from '../query-builder/select-query-builder-expression.js';
|
||||
import type { RawBuilder } from '../raw-builder/raw-builder.js';
|
||||
import type { ShallowDehydrateObject, ShallowDehydrateValue, Simplify } from '../util/type-utils.js';
|
||||
/**
|
||||
* A SQLite helper for aggregating a subquery into a JSON array.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import * as Sqlite from 'better-sqlite3'
|
||||
* import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new SqliteDialect({
|
||||
* database: new Sqlite(':memory:')
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonArrayFrom } from 'kysely/helpers/sqlite'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonArrayFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .orderBy('pet.name')
|
||||
* ).as('pets')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.pets[0].pet_id
|
||||
* result[0]?.pets[0].name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (SQLite):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select coalesce(json_group_array(json_object(
|
||||
* 'pet_id', "agg"."pet_id",
|
||||
* 'name', "agg"."name"
|
||||
* )), '[]') from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* order by "pet"."name"
|
||||
* ) as "agg"
|
||||
* ) as "pets"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonArrayFrom<O>(expr: SelectQueryBuilderExpression<O>): RawBuilder<Simplify<ShallowDehydrateObject<O>>[]>;
|
||||
/**
|
||||
* A SQLite helper for turning a subquery into a JSON object.
|
||||
*
|
||||
* The subquery must only return one row.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import * as Sqlite from 'better-sqlite3'
|
||||
* import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new SqliteDialect({
|
||||
* database: new Sqlite(':memory:')
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonObjectFrom } from 'kysely/helpers/sqlite'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonObjectFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .where('pet.is_favorite', '=', true)
|
||||
* ).as('favorite_pet')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.favorite_pet?.pet_id
|
||||
* result[0]?.favorite_pet?.name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (SQLite):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select json_object(
|
||||
* 'pet_id', "obj"."pet_id",
|
||||
* 'name', "obj"."name"
|
||||
* ) from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* and "pet"."is_favorite" = ?
|
||||
* ) as obj
|
||||
* ) as "favorite_pet"
|
||||
* from "person";
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonObjectFrom<O>(expr: SelectQueryBuilderExpression<O>): RawBuilder<Simplify<ShallowDehydrateObject<O>> | null>;
|
||||
/**
|
||||
* The SQLite `json_object` function.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import * as Sqlite from 'better-sqlite3'
|
||||
* import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new SqliteDialect({
|
||||
* database: new Sqlite(':memory:')
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { sql } from 'kysely'
|
||||
* import { jsonBuildObject } from 'kysely/helpers/sqlite'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonBuildObject({
|
||||
* first: eb.ref('first_name'),
|
||||
* last: eb.ref('last_name'),
|
||||
* full: sql<string>`first_name || ' ' || last_name`
|
||||
* }).as('name')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.name.first
|
||||
* result[0]?.name.last
|
||||
* result[0]?.name.full
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (SQLite):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", json_object(
|
||||
* 'first', first_name,
|
||||
* 'last', last_name,
|
||||
* 'full', "first_name" || ' ' || "last_name"
|
||||
* ) as "name"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export declare function jsonBuildObject<O extends Record<string, Expression<unknown>>>(obj: O): RawBuilder<Simplify<{
|
||||
[K in keyof O]: O[K] extends Expression<infer V> ? ShallowDehydrateValue<V> : never;
|
||||
}>>;
|
||||
200
node_modules/kysely/dist/esm/helpers/sqlite.js
generated
vendored
Normal file
200
node_modules/kysely/dist/esm/helpers/sqlite.js
generated
vendored
Normal file
@@ -0,0 +1,200 @@
|
||||
/// <reference types="./sqlite.d.ts" />
|
||||
import { sql } from '../raw-builder/sql.js';
|
||||
import { getJsonObjectArgs } from '../util/json-object-args.js';
|
||||
/**
|
||||
* A SQLite helper for aggregating a subquery into a JSON array.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import * as Sqlite from 'better-sqlite3'
|
||||
* import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new SqliteDialect({
|
||||
* database: new Sqlite(':memory:')
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonArrayFrom } from 'kysely/helpers/sqlite'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonArrayFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .orderBy('pet.name')
|
||||
* ).as('pets')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.pets[0].pet_id
|
||||
* result[0]?.pets[0].name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (SQLite):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select coalesce(json_group_array(json_object(
|
||||
* 'pet_id', "agg"."pet_id",
|
||||
* 'name', "agg"."name"
|
||||
* )), '[]') from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* order by "pet"."name"
|
||||
* ) as "agg"
|
||||
* ) as "pets"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export function jsonArrayFrom(expr) {
|
||||
return sql `(select coalesce(json_group_array(json_object(${sql.join(getSqliteJsonObjectArgs(expr.toOperationNode(), 'agg'))})), '[]') from ${expr} as agg)`;
|
||||
}
|
||||
/**
|
||||
* A SQLite helper for turning a subquery into a JSON object.
|
||||
*
|
||||
* The subquery must only return one row.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import * as Sqlite from 'better-sqlite3'
|
||||
* import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new SqliteDialect({
|
||||
* database: new Sqlite(':memory:')
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { jsonObjectFrom } from 'kysely/helpers/sqlite'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonObjectFrom(
|
||||
* eb.selectFrom('pet')
|
||||
* .select(['pet.id as pet_id', 'pet.name'])
|
||||
* .whereRef('pet.owner_id', '=', 'person.id')
|
||||
* .where('pet.is_favorite', '=', true)
|
||||
* ).as('favorite_pet')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.favorite_pet?.pet_id
|
||||
* result[0]?.favorite_pet?.name
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (SQLite):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", (
|
||||
* select json_object(
|
||||
* 'pet_id', "obj"."pet_id",
|
||||
* 'name', "obj"."name"
|
||||
* ) from (
|
||||
* select "pet"."id" as "pet_id", "pet"."name"
|
||||
* from "pet"
|
||||
* where "pet"."owner_id" = "person"."id"
|
||||
* and "pet"."is_favorite" = ?
|
||||
* ) as obj
|
||||
* ) as "favorite_pet"
|
||||
* from "person";
|
||||
* ```
|
||||
*/
|
||||
export function jsonObjectFrom(expr) {
|
||||
return sql `(select json_object(${sql.join(getSqliteJsonObjectArgs(expr.toOperationNode(), 'obj'))}) from ${expr} as obj)`;
|
||||
}
|
||||
/**
|
||||
* The SQLite `json_object` function.
|
||||
*
|
||||
* NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.
|
||||
* Otherwise the nested selections will be returned as JSON strings.
|
||||
*
|
||||
* The plugin can be installed like this:
|
||||
*
|
||||
* ```ts
|
||||
* import * as Sqlite from 'better-sqlite3'
|
||||
* import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'
|
||||
* import type { Database } from 'type-editor' // imaginary module
|
||||
*
|
||||
* const db = new Kysely<Database>({
|
||||
* dialect: new SqliteDialect({
|
||||
* database: new Sqlite(':memory:')
|
||||
* }),
|
||||
* plugins: [new ParseJSONResultsPlugin()]
|
||||
* })
|
||||
* ```
|
||||
*
|
||||
* ### Examples
|
||||
*
|
||||
* ```ts
|
||||
* import { sql } from 'kysely'
|
||||
* import { jsonBuildObject } from 'kysely/helpers/sqlite'
|
||||
*
|
||||
* const result = await db
|
||||
* .selectFrom('person')
|
||||
* .select((eb) => [
|
||||
* 'id',
|
||||
* jsonBuildObject({
|
||||
* first: eb.ref('first_name'),
|
||||
* last: eb.ref('last_name'),
|
||||
* full: sql<string>`first_name || ' ' || last_name`
|
||||
* }).as('name')
|
||||
* ])
|
||||
* .execute()
|
||||
*
|
||||
* result[0]?.id
|
||||
* result[0]?.name.first
|
||||
* result[0]?.name.last
|
||||
* result[0]?.name.full
|
||||
* ```
|
||||
*
|
||||
* The generated SQL (SQLite):
|
||||
*
|
||||
* ```sql
|
||||
* select "id", json_object(
|
||||
* 'first', first_name,
|
||||
* 'last', last_name,
|
||||
* 'full', "first_name" || ' ' || "last_name"
|
||||
* ) as "name"
|
||||
* from "person"
|
||||
* ```
|
||||
*/
|
||||
export function jsonBuildObject(obj) {
|
||||
return sql `json_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;
|
||||
}
|
||||
function getSqliteJsonObjectArgs(node, table) {
|
||||
try {
|
||||
return getJsonObjectArgs(node, table);
|
||||
}
|
||||
catch {
|
||||
throw new Error('SQLite jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.');
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user