@entity-access/entity-access 1.0.16 → 1.0.18
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/.github/workflows/node.yml +1 -0
- package/dist/compiler/QueryCompiler.js +4 -4
- package/dist/compiler/QueryCompiler.js.map +1 -1
- package/dist/decorators/Column.d.ts.map +1 -1
- package/dist/decorators/Column.js +2 -0
- package/dist/decorators/Column.js.map +1 -1
- package/dist/decorators/SchemaRegistry.d.ts +2 -0
- package/dist/decorators/SchemaRegistry.d.ts.map +1 -1
- package/dist/decorators/SchemaRegistry.js +11 -0
- package/dist/decorators/SchemaRegistry.js.map +1 -1
- package/dist/decorators/Table.d.ts +3 -1
- package/dist/decorators/Table.d.ts.map +1 -1
- package/dist/decorators/Table.js +6 -0
- package/dist/decorators/Table.js.map +1 -1
- package/dist/di/di.d.ts +1 -1
- package/dist/di/di.d.ts.map +1 -1
- package/dist/di/di.js.map +1 -1
- package/dist/drivers/sql-server/ExpressionToSqlServer.js +2 -2
- package/dist/drivers/sql-server/ExpressionToSqlServer.js.map +1 -1
- package/dist/entity-query/EntityType.d.ts +3 -2
- package/dist/entity-query/EntityType.d.ts.map +1 -1
- package/dist/entity-query/EntityType.js +3 -2
- package/dist/entity-query/EntityType.js.map +1 -1
- package/dist/model/verification/VerificationSession.js +3 -3
- package/dist/model/verification/VerificationSession.js.map +1 -1
- package/dist/query/ast/DebugStringVisitor.js +1 -1
- package/dist/query/ast/DebugStringVisitor.js.map +1 -1
- package/dist/query/ast/ExpressionToSql.js +5 -5
- package/dist/query/ast/ExpressionToSql.js.map +1 -1
- package/dist/query/ast/Expressions.d.ts +1 -1
- package/dist/query/ast/Expressions.d.ts.map +1 -1
- package/dist/query/ast/Expressions.js +1 -1
- package/dist/query/ast/Expressions.js.map +1 -1
- package/dist/query/expander/QueryExpander.js +3 -3
- package/dist/query/expander/QueryExpander.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/src/compiler/QueryCompiler.ts +4 -4
- package/src/decorators/Column.ts +2 -0
- package/src/decorators/SchemaRegistry.ts +13 -0
- package/src/decorators/Table.ts +9 -1
- package/src/di/di.ts +1 -1
- package/src/drivers/sql-server/ExpressionToSqlServer.ts +2 -2
- package/src/entity-query/EntityType.ts +3 -2
- package/src/model/verification/VerificationSession.ts +3 -3
- package/src/query/ast/DebugStringVisitor.ts +1 -1
- package/src/query/ast/ExpressionToSql.ts +5 -5
- package/src/query/ast/Expressions.ts +1 -1
- package/src/query/expander/QueryExpander.ts +5 -5
|
@@ -88,7 +88,7 @@ export default class VerificationSession {
|
|
|
88
88
|
|
|
89
89
|
const eq = query as EntityQuery;
|
|
90
90
|
const compare = Expression.equal(
|
|
91
|
-
Expression.member(eq.selectStatement.
|
|
91
|
+
Expression.member(eq.selectStatement.sourceParameter, relatedModel.keys[0].columnName),
|
|
92
92
|
Expression.constant(value)
|
|
93
93
|
);
|
|
94
94
|
const typeName = TypeInfo.nameOfType(type);
|
|
@@ -106,7 +106,7 @@ export default class VerificationSession {
|
|
|
106
106
|
const eq = query as EntityQuery;
|
|
107
107
|
for (const [key, value] of keys) {
|
|
108
108
|
const test = Expression.equal(
|
|
109
|
-
Expression.member(eq.selectStatement.
|
|
109
|
+
Expression.member(eq.selectStatement.sourceParameter, Expression.quotedLiteral(key)),
|
|
110
110
|
Expression.constant(value)
|
|
111
111
|
);
|
|
112
112
|
compare = compare
|
|
@@ -124,7 +124,7 @@ export default class VerificationSession {
|
|
|
124
124
|
this.select.fields =[
|
|
125
125
|
Expression.as(Expression.templateLiteral(this.field), "error")
|
|
126
126
|
];
|
|
127
|
-
this.select.
|
|
127
|
+
this.select.sourceParameter = ParameterExpression.create({ name: "x"});
|
|
128
128
|
const source = ValuesStatement.create({
|
|
129
129
|
values: [
|
|
130
130
|
[Identifier.create({ value: "1"})]
|
|
@@ -156,7 +156,7 @@ export default class DebugStringVisitor extends Visitor<string> {
|
|
|
156
156
|
|
|
157
157
|
visitSelectStatement(e: SelectStatement): string {
|
|
158
158
|
const select = `SELECT\n\t${this.visitArray(e.fields, ",\n\t")}\n\tFROM ${this.visit(e.source)}`;
|
|
159
|
-
const as = e.
|
|
159
|
+
const as = e.sourceParameter ? this.visit(e.sourceParameter): "";
|
|
160
160
|
const joins = e.joins?.length > 0 ? this.visitArray(e.joins, "\n\t") : "";
|
|
161
161
|
const where = e.where ? `\n\tWHERE ${this.visit(e.where)}` : "";
|
|
162
162
|
const orderBy = e.orderBy ? `\n\tORDER BY ${this.visitArray(e.orderBy, "\n\t\tTHEN BY")}`: "";
|
|
@@ -74,7 +74,7 @@ export default class ExpressionToSql extends Visitor<ITextQuery> {
|
|
|
74
74
|
const source = e.source.type === "ValuesStatement"
|
|
75
75
|
? prepare `(${this.visit(e.source)})`
|
|
76
76
|
: this.visit(e.source);
|
|
77
|
-
const as = e.
|
|
77
|
+
const as = e.sourceParameter ? prepare ` AS ${this.compiler.quotedLiteral( this.scope.nameOf(e.sourceParameter))}` : "";
|
|
78
78
|
const fields = this.visitArray(e.fields, ",\n\t\t");
|
|
79
79
|
return prepare `SELECT
|
|
80
80
|
${fields}
|
|
@@ -82,8 +82,8 @@ export default class ExpressionToSql extends Visitor<ITextQuery> {
|
|
|
82
82
|
}
|
|
83
83
|
prepareStatement(e: SelectStatement) {
|
|
84
84
|
// inject parameter and types if we don't have it..
|
|
85
|
-
if (e.
|
|
86
|
-
this.scope.create({ parameter: e.
|
|
85
|
+
if (e.sourceParameter && e.model) {
|
|
86
|
+
this.scope.create({ parameter: e.sourceParameter, selectStatement: e });
|
|
87
87
|
}
|
|
88
88
|
|
|
89
89
|
const joins = e.joins;
|
|
@@ -178,8 +178,8 @@ export default class ExpressionToSql extends Visitor<ITextQuery> {
|
|
|
178
178
|
|
|
179
179
|
param1.model = relatedModel;
|
|
180
180
|
this.scope.create({ parameter: param1, model: relatedModel, selectStatement: select });
|
|
181
|
-
this.scope.alias(param1, select.
|
|
182
|
-
select.
|
|
181
|
+
this.scope.alias(param1, select.sourceParameter, select);
|
|
182
|
+
select.sourceParameter = param1;
|
|
183
183
|
const targetKey = MemberExpression.create({
|
|
184
184
|
target: parameter,
|
|
185
185
|
property: Identifier.create({
|
|
@@ -91,11 +91,11 @@ export class QueryExpander {
|
|
|
91
91
|
|
|
92
92
|
joinWhere = Expression.equal(
|
|
93
93
|
Expression.member(
|
|
94
|
-
parent.
|
|
94
|
+
parent.sourceParameter,
|
|
95
95
|
Expression.quotedLiteral(fk.columnName)
|
|
96
96
|
),
|
|
97
97
|
Expression.member(
|
|
98
|
-
select.
|
|
98
|
+
select.sourceParameter,
|
|
99
99
|
Expression.quotedLiteral(model.keys[0].columnName)
|
|
100
100
|
)
|
|
101
101
|
);
|
|
@@ -107,7 +107,7 @@ export class QueryExpander {
|
|
|
107
107
|
const joins = (select.joins ??= []);
|
|
108
108
|
joins.push(JoinExpression.create({
|
|
109
109
|
source: parent.source as TableSource,
|
|
110
|
-
as: parent.
|
|
110
|
+
as: parent.sourceParameter,
|
|
111
111
|
model,
|
|
112
112
|
where
|
|
113
113
|
}));
|
|
@@ -117,11 +117,11 @@ export class QueryExpander {
|
|
|
117
117
|
|
|
118
118
|
joinWhere = Expression.equal(
|
|
119
119
|
Expression.member(
|
|
120
|
-
parent.
|
|
120
|
+
parent.sourceParameter,
|
|
121
121
|
Expression.quotedLiteral(fk.columnName)
|
|
122
122
|
),
|
|
123
123
|
Expression.member(
|
|
124
|
-
select.
|
|
124
|
+
select.sourceParameter,
|
|
125
125
|
Expression.quotedLiteral(relation.relatedEntity.keys[0].columnName)
|
|
126
126
|
)
|
|
127
127
|
);
|