Browse Source

fix: use alias when constructing hm filter query to avoid self-reference issue

pull/9899/head
Pranav C 1 month ago
parent
commit
cdf93e5e95
  1. 26
      packages/nocodb/src/db/conditionV2.ts

26
packages/nocodb/src/db/conditionV2.ts

@ -213,30 +213,18 @@ const parseConditionV2 = async (
filter.comparison_op,
)
) {
// handle self reference
if (parentModel.id === childModel.id) {
if (filter.comparison_op === 'blank') {
return (qb) => {
qb.whereNull(childColumn.column_name);
};
} else {
return (qb) => {
qb.whereNotNull(childColumn.column_name);
};
}
}
const childTableAlias = getAlias(aliasCount);
const selectHmCount = knex(
baseModelSqlv2.getTnPath(childModel.table_name),
baseModelSqlv2.getTnPath(childModel.table_name, childTableAlias),
)
.count(childColumn.column_name)
.where(
.whereRaw('??.?? = ??.??', [
childTableAlias,
childColumn.column_name,
knex.raw('??.??', [
alias || baseModelSqlv2.getTnPath(parentModel.table_name),
parentColumn.column_name,
]),
);
alias || baseModelSqlv2.getTnPath(parentModel.table_name),
parentColumn.column_name,
]);
return (qb) => {
if (filter.comparison_op === 'blank') {

Loading…
Cancel
Save