@mikro-orm/mysql 7.0.0-dev.33 → 7.0.0-dev.331
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/MySqlConnection.d.ts +1 -1
- package/MySqlConnection.js +2 -2
- package/MySqlDriver.d.ts +9 -5
- package/MySqlDriver.js +13 -6
- package/MySqlMikroORM.d.ts +7 -8
- package/MySqlMikroORM.js +6 -8
- package/MySqlPlatform.d.ts +4 -0
- package/MySqlPlatform.js +7 -0
- package/README.md +7 -4
- package/index.d.ts +3 -2
- package/index.js +2 -1
- package/package.json +35 -35
package/MySqlConnection.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { type ControlledTransaction, MysqlDialect } from 'kysely';
|
|
2
2
|
import { type PoolOptions } from 'mysql2';
|
|
3
|
-
import { AbstractSqlConnection, type TransactionEventBroadcaster } from '@mikro-orm/
|
|
3
|
+
import { AbstractSqlConnection, type TransactionEventBroadcaster } from '@mikro-orm/sql';
|
|
4
4
|
export declare class MySqlConnection extends AbstractSqlConnection {
|
|
5
5
|
createKyselyDialect(overrides: PoolOptions): MysqlDialect;
|
|
6
6
|
mapOptions(overrides: PoolOptions): PoolOptions;
|
package/MySqlConnection.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { MysqlDialect } from 'kysely';
|
|
2
2
|
import { createPool } from 'mysql2';
|
|
3
|
-
import { Utils, AbstractSqlConnection } from '@mikro-orm/
|
|
3
|
+
import { Utils, AbstractSqlConnection } from '@mikro-orm/sql';
|
|
4
4
|
export class MySqlConnection extends AbstractSqlConnection {
|
|
5
5
|
createKyselyDialect(overrides) {
|
|
6
6
|
const options = this.mapOptions(overrides);
|
|
@@ -43,7 +43,7 @@ export class MySqlConnection extends AbstractSqlConnection {
|
|
|
43
43
|
await ctx.releaseSavepoint(ctx.savepointName).execute();
|
|
44
44
|
}
|
|
45
45
|
catch (e) {
|
|
46
|
-
/* v8 ignore next
|
|
46
|
+
/* v8 ignore next */
|
|
47
47
|
// https://github.com/knex/knex/issues/805
|
|
48
48
|
if (e.errno !== 1305) {
|
|
49
49
|
throw e;
|
package/MySqlDriver.d.ts
CHANGED
|
@@ -1,10 +1,14 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { AbstractSqlDriver
|
|
1
|
+
import type { Configuration, Constructor, EntityDictionary, EntityName, FilterQuery, NativeInsertUpdateManyOptions, QueryResult, UpsertManyOptions } from '@mikro-orm/core';
|
|
2
|
+
import { AbstractSqlDriver } from '@mikro-orm/sql';
|
|
3
3
|
import { MySqlConnection } from './MySqlConnection.js';
|
|
4
|
+
import { MySqlMikroORM } from './MySqlMikroORM.js';
|
|
5
|
+
import { MySqlPlatform } from './MySqlPlatform.js';
|
|
4
6
|
export declare class MySqlDriver extends AbstractSqlDriver<MySqlConnection, MySqlPlatform> {
|
|
5
|
-
|
|
7
|
+
private autoIncrementIncrement?;
|
|
6
8
|
constructor(config: Configuration);
|
|
7
9
|
private getAutoIncrementIncrement;
|
|
8
|
-
nativeInsertMany<T extends object>(entityName:
|
|
9
|
-
nativeUpdateMany<T extends object>(entityName:
|
|
10
|
+
nativeInsertMany<T extends object>(entityName: EntityName<T>, data: EntityDictionary<T>[], options?: NativeInsertUpdateManyOptions<T>): Promise<QueryResult<T>>;
|
|
11
|
+
nativeUpdateMany<T extends object>(entityName: EntityName<T>, where: FilterQuery<T>[], data: EntityDictionary<T>[], options?: NativeInsertUpdateManyOptions<T> & UpsertManyOptions<T>): Promise<QueryResult<T>>;
|
|
12
|
+
/** @inheritDoc */
|
|
13
|
+
getORMClass(): Constructor<MySqlMikroORM>;
|
|
10
14
|
}
|
package/MySqlDriver.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { AbstractSqlDriver, MySqlPlatform } from '@mikro-orm/knex';
|
|
1
|
+
import { AbstractSqlDriver, Utils } from '@mikro-orm/sql';
|
|
3
2
|
import { MySqlConnection } from './MySqlConnection.js';
|
|
3
|
+
import { MySqlMikroORM } from './MySqlMikroORM.js';
|
|
4
|
+
import { MySqlPlatform } from './MySqlPlatform.js';
|
|
4
5
|
export class MySqlDriver extends AbstractSqlDriver {
|
|
5
6
|
autoIncrementIncrement;
|
|
6
7
|
constructor(config) {
|
|
@@ -18,22 +19,24 @@ export class MySqlDriver extends AbstractSqlDriver {
|
|
|
18
19
|
async nativeInsertMany(entityName, data, options = {}) {
|
|
19
20
|
options.processCollections ??= true;
|
|
20
21
|
const res = await super.nativeInsertMany(entityName, data, options);
|
|
21
|
-
const
|
|
22
|
+
const meta = this.metadata.get(entityName);
|
|
23
|
+
const pks = this.getPrimaryKeyFields(meta);
|
|
22
24
|
const ctx = options.ctx;
|
|
23
25
|
const autoIncrementIncrement = await this.getAutoIncrementIncrement(ctx);
|
|
24
|
-
data.forEach((item, idx) => res.rows[idx] = { [pks[0]]: item[pks[0]] ?? res.insertId +
|
|
26
|
+
data.forEach((item, idx) => (res.rows[idx] = { [pks[0]]: item[pks[0]] ?? res.insertId + idx * autoIncrementIncrement }));
|
|
25
27
|
res.row = res.rows[0];
|
|
26
28
|
return res;
|
|
27
29
|
}
|
|
28
30
|
async nativeUpdateMany(entityName, where, data, options = {}) {
|
|
29
31
|
const res = await super.nativeUpdateMany(entityName, where, data, options);
|
|
30
|
-
const
|
|
32
|
+
const meta = this.metadata.get(entityName);
|
|
33
|
+
const pks = this.getPrimaryKeyFields(meta);
|
|
31
34
|
const ctx = options.ctx;
|
|
32
35
|
const autoIncrementIncrement = await this.getAutoIncrementIncrement(ctx);
|
|
33
36
|
let i = 0;
|
|
34
37
|
const rows = where.map(cond => {
|
|
35
38
|
if (res.insertId != null && Utils.isEmpty(cond)) {
|
|
36
|
-
return { [pks[0]]: res.insertId +
|
|
39
|
+
return { [pks[0]]: res.insertId + i++ * autoIncrementIncrement };
|
|
37
40
|
}
|
|
38
41
|
if (cond[pks[0]] == null) {
|
|
39
42
|
return undefined;
|
|
@@ -46,4 +49,8 @@ export class MySqlDriver extends AbstractSqlDriver {
|
|
|
46
49
|
res.row = res.rows[0];
|
|
47
50
|
return res;
|
|
48
51
|
}
|
|
52
|
+
/** @inheritDoc */
|
|
53
|
+
getORMClass() {
|
|
54
|
+
return MySqlMikroORM;
|
|
55
|
+
}
|
|
49
56
|
}
|
package/MySqlMikroORM.d.ts
CHANGED
|
@@ -1,19 +1,18 @@
|
|
|
1
|
-
import { MikroORM, type Options, type IDatabaseDriver, type EntityManager, type EntityManagerType } from '@mikro-orm/core';
|
|
1
|
+
import { type AnyEntity, type EntityClass, type EntitySchema, MikroORM, type Options, type IDatabaseDriver, type EntityManager, type EntityManagerType } from '@mikro-orm/core';
|
|
2
|
+
import type { SqlEntityManager } from '@mikro-orm/sql';
|
|
2
3
|
import { MySqlDriver } from './MySqlDriver.js';
|
|
3
|
-
|
|
4
|
+
export type MySqlOptions<EM extends SqlEntityManager<MySqlDriver> = SqlEntityManager<MySqlDriver>, Entities extends (string | EntityClass<AnyEntity> | EntitySchema)[] = (string | EntityClass<AnyEntity> | EntitySchema)[]> = Partial<Options<MySqlDriver, EM, Entities>>;
|
|
5
|
+
export declare function defineMySqlConfig<EM extends SqlEntityManager<MySqlDriver> = SqlEntityManager<MySqlDriver>, Entities extends (string | EntityClass<AnyEntity> | EntitySchema)[] = (string | EntityClass<AnyEntity> | EntitySchema)[]>(options: Partial<Options<MySqlDriver, EM, Entities>>): Partial<Options<MySqlDriver, EM, Entities>>;
|
|
4
6
|
/**
|
|
5
7
|
* @inheritDoc
|
|
6
8
|
*/
|
|
7
|
-
export declare class MySqlMikroORM<EM extends
|
|
8
|
-
private static DRIVER;
|
|
9
|
+
export declare class MySqlMikroORM<EM extends SqlEntityManager<MySqlDriver> = SqlEntityManager<MySqlDriver>, Entities extends (string | EntityClass<AnyEntity> | EntitySchema)[] = (string | EntityClass<AnyEntity> | EntitySchema)[]> extends MikroORM<MySqlDriver, EM, Entities> {
|
|
9
10
|
/**
|
|
10
11
|
* @inheritDoc
|
|
11
12
|
*/
|
|
12
|
-
static init<D extends IDatabaseDriver = MySqlDriver, EM extends EntityManager = D[typeof EntityManagerType] & EntityManager>(options
|
|
13
|
+
static init<D extends IDatabaseDriver = MySqlDriver, EM extends EntityManager<D> = D[typeof EntityManagerType] & EntityManager<D>, Entities extends (string | EntityClass<AnyEntity> | EntitySchema)[] = (string | EntityClass<AnyEntity> | EntitySchema)[]>(options: Partial<Options<D, EM, Entities>>): Promise<MikroORM<D, EM, Entities>>;
|
|
13
14
|
/**
|
|
14
15
|
* @inheritDoc
|
|
15
16
|
*/
|
|
16
|
-
|
|
17
|
+
constructor(options: Partial<Options<MySqlDriver, EM, Entities>>);
|
|
17
18
|
}
|
|
18
|
-
export type MySqlOptions = Options<MySqlDriver>;
|
|
19
|
-
export declare function defineMySqlConfig(options: MySqlOptions): Options<MySqlDriver, SqlEntityManager<MySqlDriver> & EntityManager<IDatabaseDriver<import("@mikro-orm/core").Connection>>>;
|
package/MySqlMikroORM.js
CHANGED
|
@@ -1,24 +1,22 @@
|
|
|
1
1
|
import { defineConfig, MikroORM, } from '@mikro-orm/core';
|
|
2
2
|
import { MySqlDriver } from './MySqlDriver.js';
|
|
3
|
+
export function defineMySqlConfig(options) {
|
|
4
|
+
return defineConfig({ driver: MySqlDriver, ...options });
|
|
5
|
+
}
|
|
3
6
|
/**
|
|
4
7
|
* @inheritDoc
|
|
5
8
|
*/
|
|
6
9
|
export class MySqlMikroORM extends MikroORM {
|
|
7
|
-
static DRIVER = MySqlDriver;
|
|
8
10
|
/**
|
|
9
11
|
* @inheritDoc
|
|
10
12
|
*/
|
|
11
13
|
static async init(options) {
|
|
12
|
-
return super.init(options);
|
|
14
|
+
return super.init(defineMySqlConfig(options));
|
|
13
15
|
}
|
|
14
16
|
/**
|
|
15
17
|
* @inheritDoc
|
|
16
18
|
*/
|
|
17
|
-
|
|
18
|
-
|
|
19
|
+
constructor(options) {
|
|
20
|
+
super(defineMySqlConfig(options));
|
|
19
21
|
}
|
|
20
22
|
}
|
|
21
|
-
/* v8 ignore next 3 */
|
|
22
|
-
export function defineMySqlConfig(options) {
|
|
23
|
-
return defineConfig({ driver: MySqlDriver, ...options });
|
|
24
|
-
}
|
package/MySqlPlatform.js
ADDED
package/README.md
CHANGED
|
@@ -2,14 +2,14 @@
|
|
|
2
2
|
<a href="https://mikro-orm.io"><img src="https://raw.githubusercontent.com/mikro-orm/mikro-orm/master/docs/static/img/logo-readme.svg?sanitize=true" alt="MikroORM" /></a>
|
|
3
3
|
</h1>
|
|
4
4
|
|
|
5
|
-
TypeScript ORM for Node.js based on Data Mapper, [Unit of Work](https://mikro-orm.io/docs/unit-of-work/) and [Identity Map](https://mikro-orm.io/docs/identity-map/) patterns. Supports MongoDB, MySQL, MariaDB, PostgreSQL
|
|
5
|
+
TypeScript ORM for Node.js based on Data Mapper, [Unit of Work](https://mikro-orm.io/docs/unit-of-work/) and [Identity Map](https://mikro-orm.io/docs/identity-map/) patterns. Supports MongoDB, MySQL, MariaDB, PostgreSQL, SQLite (including libSQL), MSSQL and Oracle databases.
|
|
6
6
|
|
|
7
7
|
> Heavily inspired by [Doctrine](https://www.doctrine-project.org/) and [Hibernate](https://hibernate.org/).
|
|
8
8
|
|
|
9
|
-
[](https://
|
|
10
|
-
[](https://
|
|
9
|
+
[](https://npmx.dev/package/@mikro-orm/core)
|
|
10
|
+
[](https://npmx.dev/package/@mikro-orm/core)
|
|
11
11
|
[](https://discord.gg/w8bjxFHS7X)
|
|
12
|
-
[](https://
|
|
12
|
+
[](https://npmx.dev/package/@mikro-orm/core)
|
|
13
13
|
[](https://coveralls.io/r/mikro-orm/mikro-orm?branch=master)
|
|
14
14
|
[](https://github.com/mikro-orm/mikro-orm/actions?workflow=tests)
|
|
15
15
|
|
|
@@ -181,6 +181,7 @@ yarn add @mikro-orm/core @mikro-orm/mysql # for mysql/mariadb
|
|
|
181
181
|
yarn add @mikro-orm/core @mikro-orm/mariadb # for mysql/mariadb
|
|
182
182
|
yarn add @mikro-orm/core @mikro-orm/postgresql # for postgresql
|
|
183
183
|
yarn add @mikro-orm/core @mikro-orm/mssql # for mssql
|
|
184
|
+
yarn add @mikro-orm/core @mikro-orm/oracledb # for oracle
|
|
184
185
|
yarn add @mikro-orm/core @mikro-orm/sqlite # for sqlite
|
|
185
186
|
yarn add @mikro-orm/core @mikro-orm/libsql # for libsql
|
|
186
187
|
```
|
|
@@ -381,6 +382,8 @@ See also the list of contributors who [participated](https://github.com/mikro-or
|
|
|
381
382
|
|
|
382
383
|
Please ⭐️ this repository if this project helped you!
|
|
383
384
|
|
|
385
|
+
> If you'd like to support my open-source work, consider sponsoring me directly at [github.com/sponsors/b4nan](https://github.com/sponsors/b4nan).
|
|
386
|
+
|
|
384
387
|
## 📝 License
|
|
385
388
|
|
|
386
389
|
Copyright © 2018 [Martin Adámek](https://github.com/b4nan).
|
package/index.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
export * from '@mikro-orm/
|
|
1
|
+
export * from '@mikro-orm/sql';
|
|
2
2
|
export * from './MySqlDriver.js';
|
|
3
|
+
export * from './MySqlPlatform.js';
|
|
3
4
|
export * from './MySqlConnection.js';
|
|
4
|
-
export { MySqlMikroORM as MikroORM, MySqlOptions as Options, defineMySqlConfig as defineConfig, } from './MySqlMikroORM.js';
|
|
5
|
+
export { MySqlMikroORM as MikroORM, type MySqlOptions as Options, defineMySqlConfig as defineConfig, } from './MySqlMikroORM.js';
|
package/index.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
export * from '@mikro-orm/
|
|
1
|
+
export * from '@mikro-orm/sql';
|
|
2
2
|
export * from './MySqlDriver.js';
|
|
3
|
+
export * from './MySqlPlatform.js';
|
|
3
4
|
export * from './MySqlConnection.js';
|
|
4
5
|
export { MySqlMikroORM as MikroORM, defineMySqlConfig as defineConfig, } from './MySqlMikroORM.js';
|
package/package.json
CHANGED
|
@@ -1,64 +1,64 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mikro-orm/mysql",
|
|
3
|
-
"
|
|
4
|
-
"version": "7.0.0-dev.33",
|
|
3
|
+
"version": "7.0.0-dev.331",
|
|
5
4
|
"description": "TypeScript ORM for Node.js based on Data Mapper, Unit of Work and Identity Map patterns. Supports MongoDB, MySQL, PostgreSQL and SQLite databases as well as usage with vanilla JavaScript.",
|
|
6
|
-
"exports": {
|
|
7
|
-
"./package.json": "./package.json",
|
|
8
|
-
".": "./index.js"
|
|
9
|
-
},
|
|
10
|
-
"repository": {
|
|
11
|
-
"type": "git",
|
|
12
|
-
"url": "git+ssh://git@github.com/mikro-orm/mikro-orm.git"
|
|
13
|
-
},
|
|
14
5
|
"keywords": [
|
|
15
|
-
"
|
|
6
|
+
"data-mapper",
|
|
7
|
+
"ddd",
|
|
8
|
+
"entity",
|
|
9
|
+
"identity-map",
|
|
10
|
+
"javascript",
|
|
11
|
+
"js",
|
|
12
|
+
"mariadb",
|
|
13
|
+
"mikro-orm",
|
|
16
14
|
"mongo",
|
|
17
15
|
"mongodb",
|
|
18
16
|
"mysql",
|
|
19
|
-
"
|
|
17
|
+
"orm",
|
|
20
18
|
"postgresql",
|
|
21
19
|
"sqlite",
|
|
22
20
|
"sqlite3",
|
|
23
21
|
"ts",
|
|
24
22
|
"typescript",
|
|
25
|
-
"
|
|
26
|
-
"javascript",
|
|
27
|
-
"entity",
|
|
28
|
-
"ddd",
|
|
29
|
-
"mikro-orm",
|
|
30
|
-
"unit-of-work",
|
|
31
|
-
"data-mapper",
|
|
32
|
-
"identity-map"
|
|
23
|
+
"unit-of-work"
|
|
33
24
|
],
|
|
34
|
-
"
|
|
35
|
-
"license": "MIT",
|
|
25
|
+
"homepage": "https://mikro-orm.io",
|
|
36
26
|
"bugs": {
|
|
37
27
|
"url": "https://github.com/mikro-orm/mikro-orm/issues"
|
|
38
28
|
},
|
|
39
|
-
"
|
|
40
|
-
"
|
|
41
|
-
|
|
29
|
+
"license": "MIT",
|
|
30
|
+
"author": "Martin Adámek",
|
|
31
|
+
"repository": {
|
|
32
|
+
"type": "git",
|
|
33
|
+
"url": "git+ssh://git@github.com/mikro-orm/mikro-orm.git"
|
|
34
|
+
},
|
|
35
|
+
"type": "module",
|
|
36
|
+
"exports": {
|
|
37
|
+
"./package.json": "./package.json",
|
|
38
|
+
".": "./index.js"
|
|
39
|
+
},
|
|
40
|
+
"publishConfig": {
|
|
41
|
+
"access": "public"
|
|
42
42
|
},
|
|
43
43
|
"scripts": {
|
|
44
|
-
"build": "yarn
|
|
44
|
+
"build": "yarn compile && yarn copy",
|
|
45
45
|
"clean": "yarn run -T rimraf ./dist",
|
|
46
46
|
"compile": "yarn run -T tsc -p tsconfig.build.json",
|
|
47
47
|
"copy": "node ../../scripts/copy.mjs"
|
|
48
48
|
},
|
|
49
|
-
"publishConfig": {
|
|
50
|
-
"access": "public"
|
|
51
|
-
},
|
|
52
49
|
"dependencies": {
|
|
53
|
-
"@mikro-orm/
|
|
54
|
-
"
|
|
50
|
+
"@mikro-orm/sql": "7.0.0-dev.331",
|
|
51
|
+
"kysely": "0.28.11",
|
|
52
|
+
"mysql2": "3.19.1",
|
|
53
|
+
"sqlstring": "2.3.3"
|
|
55
54
|
},
|
|
56
55
|
"devDependencies": {
|
|
57
|
-
"@mikro-orm/core": "^6.
|
|
58
|
-
"kysely": "0.28.7"
|
|
56
|
+
"@mikro-orm/core": "^6.6.9"
|
|
59
57
|
},
|
|
60
58
|
"peerDependencies": {
|
|
61
|
-
"@mikro-orm/core": "7.0.0-dev.
|
|
62
|
-
|
|
59
|
+
"@mikro-orm/core": "7.0.0-dev.331"
|
|
60
|
+
},
|
|
61
|
+
"engines": {
|
|
62
|
+
"node": ">= 22.17.0"
|
|
63
63
|
}
|
|
64
64
|
}
|