orchid-orm 1.49.5 → 1.49.6

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/index.mjs CHANGED
@@ -298,6 +298,52 @@ const joinQueryChainHOF = (relPKeys, reverseJoin, joinQuery) => (joiningQuery, b
298
298
  }
299
299
  const last = chain[chain.length - 1];
300
300
  const query = "relationConfig" in last ? last.relationConfig.joinQuery(last, baseQuery) : last;
301
+ let useWhereExist = true;
302
+ if (jq.q.returnType !== "value" && jq.q.returnType !== "valueOrThrow") {
303
+ let tablePrefix;
304
+ if (jq.q.order) {
305
+ const prefix = tablePrefix = getQueryAs(jq) + ".";
306
+ useWhereExist = jq.q.order.every((o) => {
307
+ if (typeof o === "string") {
308
+ return isOwnColumn(prefix, o);
309
+ } else if (isExpression(o)) {
310
+ return false;
311
+ } else {
312
+ for (const key in o) {
313
+ if (!isOwnColumn(prefix, key)) {
314
+ return false;
315
+ }
316
+ }
317
+ return true;
318
+ }
319
+ });
320
+ }
321
+ if (useWhereExist && jq.q.select) {
322
+ const prefix = tablePrefix || getQueryAs(jq) + ".";
323
+ useWhereExist = jq.q.select.every((s) => {
324
+ if (typeof s === "string") {
325
+ return isOwnColumn(prefix, s);
326
+ } else if (isExpression(s)) {
327
+ return false;
328
+ } else if (!s) {
329
+ return false;
330
+ } else {
331
+ for (const key in s.selectAs) {
332
+ const value = s.selectAs[key];
333
+ if (typeof value !== "string" || !isOwnColumn(prefix, value)) {
334
+ return false;
335
+ }
336
+ }
337
+ return true;
338
+ }
339
+ });
340
+ }
341
+ }
342
+ if (useWhereExist) {
343
+ return jq.where({
344
+ EXISTS: { q: reverseJoin(query, jq) }
345
+ });
346
+ }
301
347
  const result = jq.join(
302
348
  { _internalJoin: reverseJoin(query, jq) },
303
349
  void 0
@@ -310,6 +356,7 @@ const joinQueryChainHOF = (relPKeys, reverseJoin, joinQuery) => (joiningQuery, b
310
356
  if (!result.q.select) result.q.select = ["*"];
311
357
  return wrapQuery(jq, result, item);
312
358
  };
359
+ const isOwnColumn = (prefix, column) => !column.includes(".") || column.startsWith(prefix);
313
360
  const selectRowNumber = (result, relPKeys) => {
314
361
  const hookSelect = result.q.hookSelect = new Map(
315
362
  result.q.hookSelect && [...result.q.hookSelect]