@eggjs/dal-runtime 3.33.0 → 3.34.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/dist/src/BaseSqlMap.d.ts +2 -2
- package/dist/src/BaseSqlMap.js +1 -1
- package/dist/src/SqlMapLoader.d.ts +2 -2
- package/dist/src/SqlMapLoader.js +1 -1
- package/dist/src/templates/base_dao.njk +150 -0
- package/dist/src/templates/dao.njk +17 -0
- package/dist/src/templates/extension.njk +17 -0
- package/dist/src/templates/templates/base_dao.njk +150 -0
- package/dist/src/templates/templates/dao.njk +17 -0
- package/dist/src/templates/templates/extension.njk +17 -0
- package/package.json +8 -6
package/dist/src/BaseSqlMap.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { SqlType, SqlMap, TableModel } from '@eggjs/dal-decorator';
|
|
2
|
-
import {
|
|
2
|
+
import { Logger } from '@eggjs/tegg';
|
|
3
3
|
export interface GenerateSqlMap {
|
|
4
4
|
name: string;
|
|
5
5
|
type: SqlType.DELETE | SqlType.UPDATE | SqlType.INSERT | SqlType.SELECT;
|
|
@@ -8,7 +8,7 @@ export interface GenerateSqlMap {
|
|
|
8
8
|
export declare class BaseSqlMapGenerator {
|
|
9
9
|
private readonly tableModel;
|
|
10
10
|
private readonly logger;
|
|
11
|
-
constructor(tableModel: TableModel, logger:
|
|
11
|
+
constructor(tableModel: TableModel, logger: Logger);
|
|
12
12
|
generateAllColumns(countIf: boolean): string;
|
|
13
13
|
generateFindByPrimary(): Array<GenerateSqlMap>;
|
|
14
14
|
generateFindByIndexes(): GenerateSqlMap[];
|
package/dist/src/BaseSqlMap.js
CHANGED
|
@@ -307,4 +307,4 @@ class BaseSqlMapGenerator {
|
|
|
307
307
|
}
|
|
308
308
|
}
|
|
309
309
|
exports.BaseSqlMapGenerator = BaseSqlMapGenerator;
|
|
310
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
310
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"BaseSqlMap.js","sourceRoot":"","sources":["../../src/BaseSqlMap.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { TableModel } from '@eggjs/dal-decorator';
|
|
2
|
-
import {
|
|
2
|
+
import { Logger } from '@eggjs/tegg';
|
|
3
3
|
import { TableSqlMap } from './TableSqlMap';
|
|
4
4
|
export declare class SqlMapLoader {
|
|
5
5
|
private readonly logger;
|
|
6
6
|
private readonly tableModel;
|
|
7
7
|
private readonly sqlMapPath;
|
|
8
|
-
constructor(tableModel: TableModel, moduleDir: string, logger:
|
|
8
|
+
constructor(tableModel: TableModel, moduleDir: string, logger: Logger);
|
|
9
9
|
load(): TableSqlMap;
|
|
10
10
|
}
|
package/dist/src/SqlMapLoader.js
CHANGED
|
@@ -32,4 +32,4 @@ class SqlMapLoader {
|
|
|
32
32
|
}
|
|
33
33
|
}
|
|
34
34
|
exports.SqlMapLoader = SqlMapLoader;
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3FsTWFwTG9hZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL1NxbE1hcExvYWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSwwREFBNkI7QUFHN0IsNkNBQW1EO0FBQ25ELCtDQUE0QztBQUU1QyxNQUFhLFlBQVk7SUFLdkIsWUFBWSxVQUFzQixFQUFFLFNBQWlCLEVBQUUsTUFBYztRQUNuRSxJQUFJLENBQUMsVUFBVSxHQUFHLG1CQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxlQUFlLEVBQUUsR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDLElBQUksY0FBYyxDQUFDLENBQUM7UUFDaEcsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDckIsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLENBQUM7SUFDL0IsQ0FBQztJQUVELElBQUk7UUFDRixJQUFJLENBQUM7WUFDSCw4REFBOEQ7WUFDOUQsTUFBTSxZQUFZLEdBQTJCLE9BQU8sQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDdEUsTUFBTSxtQkFBbUIsR0FBRyxJQUFJLGdDQUFtQixDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ2xGLE1BQU0sVUFBVSxHQUFHLG1CQUFtQixDQUFDLElBQUksRUFBRSxDQUFDO1lBQzlDLE1BQU0sTUFBTSxHQUFHO2dCQUNiLEdBQUcsVUFBVTtnQkFDYixHQUFHLFlBQVk7YUFDaEIsQ0FBQztZQUNGLE9BQU8sSUFBSSx5QkFBVyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQztRQUM3RCxDQUFDO1FBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNYLENBQUMsQ0FBQyxPQUFPLEdBQUcsZ0JBQWdCLElBQUksQ0FBQyxVQUFVLFlBQVksQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ25FLE1BQU0sQ0FBQyxDQUFDO1FBQ1YsQ0FBQztJQUNILENBQUM7Q0FDRjtBQTNCRCxvQ0EyQkMifQ==
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
{% macro newDataLogic(columns, old, new) %}
|
|
2
|
+
let tmp;
|
|
3
|
+
{% for column in table.columns %}
|
|
4
|
+
// empty-line
|
|
5
|
+
tmp = {{ old }}.{{ column.propertyName }};
|
|
6
|
+
if (tmp !== undefined) {
|
|
7
|
+
{{ new }}.${{ column.propertyName }} = tmp;
|
|
8
|
+
}
|
|
9
|
+
{% endfor %}
|
|
10
|
+
{% endmacro %}
|
|
11
|
+
|
|
12
|
+
{% macro findLogic(funcName, sqlName, idx, uniq) %}
|
|
13
|
+
public async {{ funcName }}(
|
|
14
|
+
{% for key in idx.keys %}
|
|
15
|
+
${{ key.propertyName }}: {{columnMap[key.propertyName].type.type | dbTypeToTSType}}{% if loop.last !== true %},{% endif%}
|
|
16
|
+
{% endfor %}
|
|
17
|
+
): Promise<{{ clazzName }}{{ '| null' if uniq else '[]' }}> {
|
|
18
|
+
return this.dataSource.{{ 'executeScalar' if uniq else 'execute' }}('{{ sqlName }}', {
|
|
19
|
+
{% for key in idx.keys %}
|
|
20
|
+
${{ key.propertyName }},
|
|
21
|
+
{% endfor %}
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
{% endmacro %}
|
|
25
|
+
|
|
26
|
+
{% macro generatePrimaryType(primary) %}
|
|
27
|
+
{% if (primary.keys | length) === 1 %}
|
|
28
|
+
{{primary.keys[0].propertyName}}: {{ columnMap[primary.keys[0].propertyName].type.type | dbTypeToTSType}}
|
|
29
|
+
{% else %}
|
|
30
|
+
primary: {
|
|
31
|
+
{% for key in primary.keys %}
|
|
32
|
+
{{ key.propertyName }}: {{columnMap[key.propertyName].type.type | dbTypeToTSType}}{% if loop.last !== true %},{% endif%}
|
|
33
|
+
{% endfor %}
|
|
34
|
+
}
|
|
35
|
+
{% endif %}
|
|
36
|
+
{% endmacro %}
|
|
37
|
+
|
|
38
|
+
{% macro generateUpdateValue(primary) %}
|
|
39
|
+
{% if (primary.keys | length) === 1 %}
|
|
40
|
+
const newData: Record<string, any> = {
|
|
41
|
+
primary: {
|
|
42
|
+
{{primary.keys[0].propertyName}},
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
{% else %}
|
|
46
|
+
const newData: Record<string, any> = {
|
|
47
|
+
primary,
|
|
48
|
+
};
|
|
49
|
+
{% endif %}
|
|
50
|
+
{% endmacro %}
|
|
51
|
+
|
|
52
|
+
{% macro generateDeleteValue(primary) %}
|
|
53
|
+
{% if (primary.keys | length) === 1 %}
|
|
54
|
+
{
|
|
55
|
+
{{primary.keys[0].propertyName}},
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
{% else %}
|
|
59
|
+
primary
|
|
60
|
+
{% endif %}
|
|
61
|
+
{% endmacro %}
|
|
62
|
+
|
|
63
|
+
{% macro generateInsertType(primary) %}
|
|
64
|
+
Optional<{{clazzName}},
|
|
65
|
+
{% for key in primary.keys %}
|
|
66
|
+
'{{ key.propertyName }}'{% if loop.last !== true %}|{% endif%}
|
|
67
|
+
{% endfor %}
|
|
68
|
+
>
|
|
69
|
+
{% endmacro %}
|
|
70
|
+
|
|
71
|
+
import type { InsertResult, UpdateResult, DeleteResult } from '@eggjs/rds/lib/types';
|
|
72
|
+
import { SingletonProto, AccessLevel, Inject } from '@eggjs/tegg';
|
|
73
|
+
import { DataSource, DataSourceInjectName, DataSourceQualifier, ColumnTsType } from '@eggjs/tegg/dal';
|
|
74
|
+
import { {{ clazzName }} } from '{{ tableModelPath }}';
|
|
75
|
+
// empty-line
|
|
76
|
+
type Optional<T, K extends keyof T> = Omit<T, K> & Partial<T>;
|
|
77
|
+
/**
|
|
78
|
+
* 自动生成的 {{ clazzName }}DAO 基类
|
|
79
|
+
* @class Base{{ clazzName }}DAO
|
|
80
|
+
* @classdesc 该文件由 @eggjs/tegg 自动生成,请**不要**修改它!
|
|
81
|
+
*/
|
|
82
|
+
/* istanbul ignore next */
|
|
83
|
+
@SingletonProto({
|
|
84
|
+
accessLevel: AccessLevel.PUBLIC,
|
|
85
|
+
})
|
|
86
|
+
export class Base{{ clazzName }}DAO {
|
|
87
|
+
static clazzModel = {{ clazzName }};
|
|
88
|
+
|
|
89
|
+
@Inject({
|
|
90
|
+
name: DataSourceInjectName,
|
|
91
|
+
})
|
|
92
|
+
@DataSourceQualifier('{{moduleName}}.{{ table.dataSourceName }}.{{ clazzName }}')
|
|
93
|
+
protected readonly dataSource: DataSource<{{clazzName}}>;
|
|
94
|
+
|
|
95
|
+
// empty-line
|
|
96
|
+
{# insert: 插入 #}
|
|
97
|
+
public async insert(raw: {{generateInsertType(primaryIndex)}}): Promise<InsertResult> {
|
|
98
|
+
const data: Record<string, any> = {};
|
|
99
|
+
|
|
100
|
+
{{ newDataLogic(columns, 'raw', 'data') }}
|
|
101
|
+
|
|
102
|
+
// empty-line
|
|
103
|
+
return this.dataSource.executeRawScalar('insert', data);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
// empty-line
|
|
107
|
+
{# update: 更新 #}
|
|
108
|
+
public async update({{generatePrimaryType(primaryIndex)}}, data: Partial<{{ ((clazzName)) }}>): Promise<UpdateResult> {
|
|
109
|
+
// empty-line
|
|
110
|
+
{{ generateUpdateValue(primaryIndex) }}
|
|
111
|
+
|
|
112
|
+
{{ newDataLogic(columns, 'data', 'newData') }}
|
|
113
|
+
|
|
114
|
+
// empty-line
|
|
115
|
+
return this.dataSource.executeRawScalar('update', newData);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
{% for funcName in [ 'delete', 'del' ] %}
|
|
119
|
+
// empty-line
|
|
120
|
+
{# delete: 删除 #}
|
|
121
|
+
public async {{ funcName }}({{generatePrimaryType(primaryIndex)}}): Promise<DeleteResult> {
|
|
122
|
+
return this.dataSource.executeRawScalar('delete', {{generateDeleteValue(primaryIndex)}});
|
|
123
|
+
}
|
|
124
|
+
{% endfor %}
|
|
125
|
+
|
|
126
|
+
{% for idx in table.indices %}
|
|
127
|
+
// empty-line
|
|
128
|
+
{# 某个索引 #}
|
|
129
|
+
{% set tmpName = ((idx.keys[0].propertyName if (idx.keys | length) === 1 else idx.name) | pascalCase) %}
|
|
130
|
+
{% set findName = 'findBy' + tmpName %}
|
|
131
|
+
{% set findOneName = 'findOneBy' + tmpName %}
|
|
132
|
+
{{ findLogic(findName, findName, idx, false) }}
|
|
133
|
+
// empty-line
|
|
134
|
+
{{ findLogic(findOneName, findOneName, idx, true) }}
|
|
135
|
+
{% endfor %}
|
|
136
|
+
|
|
137
|
+
// empty-line
|
|
138
|
+
{# 某个索引 #}
|
|
139
|
+
{% if primaryIndex %}
|
|
140
|
+
{% set tmpName = ((primaryIndex.keys[0].propertyName if (primaryIndex.keys | length) === 1 else primaryIndex.name) | pascalCase) %}
|
|
141
|
+
{% set findName = 'findBy' + tmpName %}
|
|
142
|
+
{% set findOneName = 'findOneBy' + tmpName %}
|
|
143
|
+
{{ findLogic(findName, findName, primaryIndex, true) }}
|
|
144
|
+
{% if (primaryIndex.keys | length) === 1 %}
|
|
145
|
+
// empty-line
|
|
146
|
+
{{ findLogic('findByPrimary', findName, primaryIndex, true) }}
|
|
147
|
+
{% endif %}
|
|
148
|
+
{% endif %}
|
|
149
|
+
}
|
|
150
|
+
// empty-line
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { SingletonProto, AccessLevel } from '@eggjs/tegg';
|
|
2
|
+
import { Base{{ clazzName }}DAO } from './base/Base{{ clazzName }}DAO';
|
|
3
|
+
// empty-line
|
|
4
|
+
/**
|
|
5
|
+
* {{ clazzName }}DAO 类
|
|
6
|
+
{% if user.name %} * @author {{ user.name }} {% if user.email %}<{{ user.email }}>{% endif %}
|
|
7
|
+
{% endif %} * @class {{ clazzName }}DAO
|
|
8
|
+
* @classdesc 在此扩展关于 {{ clazzName }} 数据的一切操作
|
|
9
|
+
* @extends Base{{ clazzName }}DAO
|
|
10
|
+
*/
|
|
11
|
+
@SingletonProto({
|
|
12
|
+
accessLevel: AccessLevel.PUBLIC,
|
|
13
|
+
})
|
|
14
|
+
export default class {{ clazzName }}DAO extends Base{{ clazzName }}DAO {
|
|
15
|
+
// empty-line
|
|
16
|
+
}
|
|
17
|
+
// empty-line
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { SqlMap } from '@eggjs/tegg/dal';
|
|
2
|
+
// empty-line
|
|
3
|
+
/**
|
|
4
|
+
* Define Custom SQLs
|
|
5
|
+
*
|
|
6
|
+
* import { SqlMap, SqlType } from '@eggjs/tegg/dal';
|
|
7
|
+
*
|
|
8
|
+
* export default {
|
|
9
|
+
* findByName: {
|
|
10
|
+
* type: SqlType.SELECT,
|
|
11
|
+
* sql: 'SELECT {{ allColumns }} from foo where name = {{ name }}'
|
|
12
|
+
* },
|
|
13
|
+
* }
|
|
14
|
+
*/
|
|
15
|
+
export default {
|
|
16
|
+
// empty-line
|
|
17
|
+
} as Record<string, SqlMap>;
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
{% macro newDataLogic(columns, old, new) %}
|
|
2
|
+
let tmp;
|
|
3
|
+
{% for column in table.columns %}
|
|
4
|
+
// empty-line
|
|
5
|
+
tmp = {{ old }}.{{ column.propertyName }};
|
|
6
|
+
if (tmp !== undefined) {
|
|
7
|
+
{{ new }}.${{ column.propertyName }} = tmp;
|
|
8
|
+
}
|
|
9
|
+
{% endfor %}
|
|
10
|
+
{% endmacro %}
|
|
11
|
+
|
|
12
|
+
{% macro findLogic(funcName, sqlName, idx, uniq) %}
|
|
13
|
+
public async {{ funcName }}(
|
|
14
|
+
{% for key in idx.keys %}
|
|
15
|
+
${{ key.propertyName }}: {{columnMap[key.propertyName].type.type | dbTypeToTSType}}{% if loop.last !== true %},{% endif%}
|
|
16
|
+
{% endfor %}
|
|
17
|
+
): Promise<{{ clazzName }}{{ '| null' if uniq else '[]' }}> {
|
|
18
|
+
return this.dataSource.{{ 'executeScalar' if uniq else 'execute' }}('{{ sqlName }}', {
|
|
19
|
+
{% for key in idx.keys %}
|
|
20
|
+
${{ key.propertyName }},
|
|
21
|
+
{% endfor %}
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
{% endmacro %}
|
|
25
|
+
|
|
26
|
+
{% macro generatePrimaryType(primary) %}
|
|
27
|
+
{% if (primary.keys | length) === 1 %}
|
|
28
|
+
{{primary.keys[0].propertyName}}: {{ columnMap[primary.keys[0].propertyName].type.type | dbTypeToTSType}}
|
|
29
|
+
{% else %}
|
|
30
|
+
primary: {
|
|
31
|
+
{% for key in primary.keys %}
|
|
32
|
+
{{ key.propertyName }}: {{columnMap[key.propertyName].type.type | dbTypeToTSType}}{% if loop.last !== true %},{% endif%}
|
|
33
|
+
{% endfor %}
|
|
34
|
+
}
|
|
35
|
+
{% endif %}
|
|
36
|
+
{% endmacro %}
|
|
37
|
+
|
|
38
|
+
{% macro generateUpdateValue(primary) %}
|
|
39
|
+
{% if (primary.keys | length) === 1 %}
|
|
40
|
+
const newData: Record<string, any> = {
|
|
41
|
+
primary: {
|
|
42
|
+
{{primary.keys[0].propertyName}},
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
{% else %}
|
|
46
|
+
const newData: Record<string, any> = {
|
|
47
|
+
primary,
|
|
48
|
+
};
|
|
49
|
+
{% endif %}
|
|
50
|
+
{% endmacro %}
|
|
51
|
+
|
|
52
|
+
{% macro generateDeleteValue(primary) %}
|
|
53
|
+
{% if (primary.keys | length) === 1 %}
|
|
54
|
+
{
|
|
55
|
+
{{primary.keys[0].propertyName}},
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
{% else %}
|
|
59
|
+
primary
|
|
60
|
+
{% endif %}
|
|
61
|
+
{% endmacro %}
|
|
62
|
+
|
|
63
|
+
{% macro generateInsertType(primary) %}
|
|
64
|
+
Optional<{{clazzName}},
|
|
65
|
+
{% for key in primary.keys %}
|
|
66
|
+
'{{ key.propertyName }}'{% if loop.last !== true %}|{% endif%}
|
|
67
|
+
{% endfor %}
|
|
68
|
+
>
|
|
69
|
+
{% endmacro %}
|
|
70
|
+
|
|
71
|
+
import type { InsertResult, UpdateResult, DeleteResult } from '@eggjs/rds/lib/types';
|
|
72
|
+
import { SingletonProto, AccessLevel, Inject } from '@eggjs/tegg';
|
|
73
|
+
import { DataSource, DataSourceInjectName, DataSourceQualifier, ColumnTsType } from '@eggjs/tegg/dal';
|
|
74
|
+
import { {{ clazzName }} } from '{{ tableModelPath }}';
|
|
75
|
+
// empty-line
|
|
76
|
+
type Optional<T, K extends keyof T> = Omit<T, K> & Partial<T>;
|
|
77
|
+
/**
|
|
78
|
+
* 自动生成的 {{ clazzName }}DAO 基类
|
|
79
|
+
* @class Base{{ clazzName }}DAO
|
|
80
|
+
* @classdesc 该文件由 @eggjs/tegg 自动生成,请**不要**修改它!
|
|
81
|
+
*/
|
|
82
|
+
/* istanbul ignore next */
|
|
83
|
+
@SingletonProto({
|
|
84
|
+
accessLevel: AccessLevel.PUBLIC,
|
|
85
|
+
})
|
|
86
|
+
export class Base{{ clazzName }}DAO {
|
|
87
|
+
static clazzModel = {{ clazzName }};
|
|
88
|
+
|
|
89
|
+
@Inject({
|
|
90
|
+
name: DataSourceInjectName,
|
|
91
|
+
})
|
|
92
|
+
@DataSourceQualifier('{{moduleName}}.{{ table.dataSourceName }}.{{ clazzName }}')
|
|
93
|
+
protected readonly dataSource: DataSource<{{clazzName}}>;
|
|
94
|
+
|
|
95
|
+
// empty-line
|
|
96
|
+
{# insert: 插入 #}
|
|
97
|
+
public async insert(raw: {{generateInsertType(primaryIndex)}}): Promise<InsertResult> {
|
|
98
|
+
const data: Record<string, any> = {};
|
|
99
|
+
|
|
100
|
+
{{ newDataLogic(columns, 'raw', 'data') }}
|
|
101
|
+
|
|
102
|
+
// empty-line
|
|
103
|
+
return this.dataSource.executeRawScalar('insert', data);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
// empty-line
|
|
107
|
+
{# update: 更新 #}
|
|
108
|
+
public async update({{generatePrimaryType(primaryIndex)}}, data: Partial<{{ ((clazzName)) }}>): Promise<UpdateResult> {
|
|
109
|
+
// empty-line
|
|
110
|
+
{{ generateUpdateValue(primaryIndex) }}
|
|
111
|
+
|
|
112
|
+
{{ newDataLogic(columns, 'data', 'newData') }}
|
|
113
|
+
|
|
114
|
+
// empty-line
|
|
115
|
+
return this.dataSource.executeRawScalar('update', newData);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
{% for funcName in [ 'delete', 'del' ] %}
|
|
119
|
+
// empty-line
|
|
120
|
+
{# delete: 删除 #}
|
|
121
|
+
public async {{ funcName }}({{generatePrimaryType(primaryIndex)}}): Promise<DeleteResult> {
|
|
122
|
+
return this.dataSource.executeRawScalar('delete', {{generateDeleteValue(primaryIndex)}});
|
|
123
|
+
}
|
|
124
|
+
{% endfor %}
|
|
125
|
+
|
|
126
|
+
{% for idx in table.indices %}
|
|
127
|
+
// empty-line
|
|
128
|
+
{# 某个索引 #}
|
|
129
|
+
{% set tmpName = ((idx.keys[0].propertyName if (idx.keys | length) === 1 else idx.name) | pascalCase) %}
|
|
130
|
+
{% set findName = 'findBy' + tmpName %}
|
|
131
|
+
{% set findOneName = 'findOneBy' + tmpName %}
|
|
132
|
+
{{ findLogic(findName, findName, idx, false) }}
|
|
133
|
+
// empty-line
|
|
134
|
+
{{ findLogic(findOneName, findOneName, idx, true) }}
|
|
135
|
+
{% endfor %}
|
|
136
|
+
|
|
137
|
+
// empty-line
|
|
138
|
+
{# 某个索引 #}
|
|
139
|
+
{% if primaryIndex %}
|
|
140
|
+
{% set tmpName = ((primaryIndex.keys[0].propertyName if (primaryIndex.keys | length) === 1 else primaryIndex.name) | pascalCase) %}
|
|
141
|
+
{% set findName = 'findBy' + tmpName %}
|
|
142
|
+
{% set findOneName = 'findOneBy' + tmpName %}
|
|
143
|
+
{{ findLogic(findName, findName, primaryIndex, true) }}
|
|
144
|
+
{% if (primaryIndex.keys | length) === 1 %}
|
|
145
|
+
// empty-line
|
|
146
|
+
{{ findLogic('findByPrimary', findName, primaryIndex, true) }}
|
|
147
|
+
{% endif %}
|
|
148
|
+
{% endif %}
|
|
149
|
+
}
|
|
150
|
+
// empty-line
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { SingletonProto, AccessLevel } from '@eggjs/tegg';
|
|
2
|
+
import { Base{{ clazzName }}DAO } from './base/Base{{ clazzName }}DAO';
|
|
3
|
+
// empty-line
|
|
4
|
+
/**
|
|
5
|
+
* {{ clazzName }}DAO 类
|
|
6
|
+
{% if user.name %} * @author {{ user.name }} {% if user.email %}<{{ user.email }}>{% endif %}
|
|
7
|
+
{% endif %} * @class {{ clazzName }}DAO
|
|
8
|
+
* @classdesc 在此扩展关于 {{ clazzName }} 数据的一切操作
|
|
9
|
+
* @extends Base{{ clazzName }}DAO
|
|
10
|
+
*/
|
|
11
|
+
@SingletonProto({
|
|
12
|
+
accessLevel: AccessLevel.PUBLIC,
|
|
13
|
+
})
|
|
14
|
+
export default class {{ clazzName }}DAO extends Base{{ clazzName }}DAO {
|
|
15
|
+
// empty-line
|
|
16
|
+
}
|
|
17
|
+
// empty-line
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { SqlMap } from '@eggjs/tegg/dal';
|
|
2
|
+
// empty-line
|
|
3
|
+
/**
|
|
4
|
+
* Define Custom SQLs
|
|
5
|
+
*
|
|
6
|
+
* import { SqlMap, SqlType } from '@eggjs/tegg/dal';
|
|
7
|
+
*
|
|
8
|
+
* export default {
|
|
9
|
+
* findByName: {
|
|
10
|
+
* type: SqlType.SELECT,
|
|
11
|
+
* sql: 'SELECT {{ allColumns }} from foo where name = {{ name }}'
|
|
12
|
+
* },
|
|
13
|
+
* }
|
|
14
|
+
*/
|
|
15
|
+
export default {
|
|
16
|
+
// empty-line
|
|
17
|
+
} as Record<string, SqlMap>;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@eggjs/dal-runtime",
|
|
3
|
-
"version": "3.
|
|
3
|
+
"version": "3.34.0",
|
|
4
4
|
"description": "tegg dal decorator",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"egg",
|
|
@@ -12,14 +12,16 @@
|
|
|
12
12
|
"main": "dist/index.js",
|
|
13
13
|
"files": [
|
|
14
14
|
"dist/**/*.js",
|
|
15
|
-
"dist/**/*.d.ts"
|
|
15
|
+
"dist/**/*.d.ts",
|
|
16
|
+
"dist/**/*.njk"
|
|
16
17
|
],
|
|
17
18
|
"typings": "dist/index.d.ts",
|
|
18
19
|
"scripts": {
|
|
19
20
|
"test": "cross-env NODE_ENV=test NODE_OPTIONS='--no-deprecation' mocha",
|
|
20
21
|
"clean": "tsc -b --clean",
|
|
21
22
|
"tsc": "npm run clean && tsc -p ./tsconfig.json",
|
|
22
|
-
"tsc:pub": "npm run clean && tsc -p ./tsconfig.pub.json",
|
|
23
|
+
"tsc:pub": "npm run clean && tsc -p ./tsconfig.pub.json && npm run cp:template",
|
|
24
|
+
"cp:template": "cp -r src/templates dist/src/templates",
|
|
23
25
|
"prepublishOnly": "npm run tsc:pub"
|
|
24
26
|
},
|
|
25
27
|
"author": "killagu <killa123@126.com>",
|
|
@@ -37,7 +39,7 @@
|
|
|
37
39
|
"node": ">=14.0.0"
|
|
38
40
|
},
|
|
39
41
|
"dependencies": {
|
|
40
|
-
"@eggjs/dal-decorator": "^3.
|
|
42
|
+
"@eggjs/dal-decorator": "^3.34.0",
|
|
41
43
|
"@eggjs/rds": "^1.0.0",
|
|
42
44
|
"js-beautify": "^1.15.1",
|
|
43
45
|
"lodash": "^4.17.21",
|
|
@@ -49,7 +51,7 @@
|
|
|
49
51
|
"access": "public"
|
|
50
52
|
},
|
|
51
53
|
"devDependencies": {
|
|
52
|
-
"@eggjs/tegg": "^3.
|
|
54
|
+
"@eggjs/tegg": "^3.34.0",
|
|
53
55
|
"@types/lodash": "^4.17.0",
|
|
54
56
|
"@types/mocha": "^10.0.1",
|
|
55
57
|
"@types/node": "^20.2.4",
|
|
@@ -59,5 +61,5 @@
|
|
|
59
61
|
"ts-node": "^10.9.1",
|
|
60
62
|
"typescript": "^5.0.4"
|
|
61
63
|
},
|
|
62
|
-
"gitHead": "
|
|
64
|
+
"gitHead": "5ec94efd8ed5eb10b27d37ef081da4ecfd4e263f"
|
|
63
65
|
}
|