Микро-орм: обновление с помощью оператора select

Я пытаюсь обновить столбец таблицы, который зависит еще от одной таблицы. Запрос sql работает нормально в базе данных и не смог определить запрос микро-ормы для этого. Ниже приведены запросы sql и mikro-orm, которые я пробовал. Микро-орм не принимает запросы на обновление как необработанные запросы. Может ли кто-нибудь мне помочь или хотя бы помочь мне в этом?

UPDATE schema.control_subs AS s
SET cancel_date = CASE 
        WHEN :input_date < c.start_date THEN c.start_date
        ELSE :input_date
    END
FROM schema.controls AS c
WHERE s.control_id = c._id
AND s.control_id IN (:controlIds);
await this.em
  .createQueryBuilder(ControlSubs)
  .update({
    cancel_date: this.em
      .createQueryBuilder(Controls, "c")
      .select(
        // raw(`CASE WHEN ${cancelDate} < c.start_date THEN c.start_date ELSE ${cancelDate} END`)
        raw(
            `CASE WHEN 
                TIMESTAMP ${cancelDate
                    .toISOString()} AT TIME ZONE 'UTC' < c.start_date 
                THEN c.start_date 
                ELSE TIMESTAMP ${cancelDate.toISOString()} AT TIME ZONE 'UTC' END`,
        ),
      )
      .where("c._id = s.control_id"),
  })
  .where({
    s.control_id: { $in: controlIds },
  });

Я пробовал это Как добавить выражение CASE в построитель запросов mikro-orm? но выражение сейчас недоступно.

Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
0
57
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я изменил запрос таким образом, чтобы часть обновления брала даты в зависимости от условий и объединяла таблицы с помощью .join(). Вот обновленный запрос.

await this.em
  .createQueryBuilder(ControlSubs, 'cs')
  .update({
    cancel_date: raw(
      `
      CASE 
        WHEN ? < ( SELECT start_date FROM schema.controls WHERE _id = cs.control_id)
        THEN (SELECT start_date FROM schema.controls WHERE _id = cs.control_id)
        ELSE ?
      END
      `,
      [cancelDate, cancelDate],
    ),
  }).join('cs.control_id', 'c')
  .where({
    s.control_id: { $in: controlIds },
  });

Было бы здорово, если бы кто-нибудь рассмотрел его и дал какие-либо предложения по его улучшению.

Другие вопросы по теме

Похожие вопросы