Хобрук: Ваш путь к мастерству в программировании

Как я могу вставить или обновить строку со значением, возвращаемым из подзапроса?

РЕДАКТИРОВАТЬ: Ищу помощи от Дж. Леффлера, Cheese Con Queso или любого, кто хорошо знает Informix-SE.

Информикс-SE 4.11:

У меня есть таблица под названием «cuadre», которая используется для согласования денежного ящика в конце каждого рабочего дня (с понедельника по субботу). После выверки ящика сумма в денежном ящике сохраняется в столбце «cu_sa_cash», строка сохраняется, система выключается, магазин закрывается на день, и мы все идем пить пиво. рабочий день, мы запускаем систему, запускаем процедуру SQL, которая создает (вставляет) новую строку в таблицу cuadre для проводок этого дня и повторяет цикл снова.

Я хотел бы, чтобы мой SQL-процесс ВСТАВИЛ новую строку на текущий день с той же суммой наличных денег в ящике, которая была сохранена в строке предыдущих рабочих дней. Имейте в виду, что это не SPL, так как я все еще использую SE 4.11. Итак, приведенные ниже операторы SQL являются общей идеей того, чего я хочу достичь, но они не работают!.. Можете ли вы предоставить мне решение?.. Спасибо!

INSERT INTO cuadre(cu_date,cu_en_dincaja)
     VALUES (TODAY,(SELECT cu_sa_cash
                      FROM cuadre
                     WHERE cu_date = (SELECT MAX(cu_date)
                                        FROM cuadre)));

or

INSERT INTO cuadre(cu_date)
     VALUES(TODAY);   

UPDATE cuadre
   SET cu_en_dincaja = (SELECT cu_sa_cash
                          FROM cuadre
                         WHERE cu_date = TODAY - 1)
 WHERE cu_date = TODAY; 

  • Этот ответ (на ваш вопрос!) говорит, что вы не можете сделать это в Informix-SE: stackoverflow.com/questions/3083609/ 15.10.2011
  • да, забыл, что спрашивал об этом больше года назад.. думаю, мне придется использовать временную таблицу для хранения cu_sa_cash из max(cu_date) 15.10.2011

Ответы:


1

Я ничего не знаю об информиксе, но это альтернативный синтаксис...

INSERT INTO
  cuadre (
    cu_date,
    cu_en_dincaja
  )
SELECT
  TODAY,
  cu_sa_cash
FROM
  cuadre
WHERE
  cu_date = (SELECT * FROM (SELECT MAX(cu_date) FROM cuadre))
;

ПРИМЕЧАНИЕ. Это может вернуть несколько строк, если cu_date не уникален.

EDIT Добавлен обходной путь MySQL для чтения из и записи в одну и ту же таблицу. Стоит ли тестировать в Informix?

14.10.2011
  • спасибо!.. не беспокойтесь, cu_date имеет уникальный индекс, так как есть только один денежный ящик, который нужно сверять каждый день.. я попробую 14.10.2011
  • Вы не можете сделать это в Informix. Вам нужно SELECT INTO TEMP t1, затем INSERT SELECT * FROM t1 (в основном существует целый ряд проблем типа ISOLATION LEVEL с синтаксисом одного оператора.) 15.10.2011
  • В SE вы не можете выбрать из таблицы, в которую вы вставляете. В IDS можно, IIRC. С SE вам придется использовать временную таблицу или что-то подобное. 17.10.2011
  • MySQL имеет аналогичное ограничение на невозможность чтения и вставки в одну и ту же таблицу. Однако для этого есть обходной путь, который кажется странным, но, по-видимому, работает... WHERE cu_date = (SELECT * FROM (SELECT MAX(cu_date) FROM cuadre)) 17.10.2011
  • Решение заключалось в использовании временной таблицы. 22.10.2011

  • 2

    использование временной таблицы было решением проблемы

    22.10.2011
    Новые материалы

    Основы принципов S.O.L.I.D, Javascript, Git и NoSQL
    каковы принципы S.O.L.I.D? Принципы SOLID призваны помочь разработчикам создавать надежные, удобные в сопровождении приложения. мы видим пять ключевых принципов. Принципы SOLID были разработаны..

    Как настроить Selenium в проекте Angular
    Угловой | Селен Как настроить Selenium в проекте Angular Держите свое приложение Angular и тесты Selenium в одной рабочей области и запускайте их с помощью Mocha. В этой статье мы..

    Аргументы прогрессивного улучшения почти всегда упускают суть
    В наши дни в кругах веб-разработчиков много болтают о Progressive Enhancement — PE, но на самом деле почти все аргументы с обеих сторон упускают самую фундаментальную причину, по которой PE..

    Введение в Джанго Фреймворк
    Схема «работать умно, а не усердно» В этой и последующих статьях я познакомлю вас с тем, что такое фреймворк Django и как создать свое первое приложение с помощью простых и понятных шагов, а..

    Настольный ПК как «одно кольцо, чтобы править всеми» домашних компьютеров
    Вид после 9 месяцев использования С настольных компьютеров все началось, но в какой-то момент они стали «серверами», и мы все перешли на ноутбуки. В прошлом году я столкнулся с идеей настольных..

    Расширенные методы безопасности для VueJS: реализация аутентификации без пароля
    Руководство, которое поможет вам создавать безопасные приложения в долгосрочной перспективе Безопасность приложений часто упускается из виду в процессе разработки, потому что основная..

    стройный-i18следующий
    Представляем стройную оболочку для i18next. Эта библиотека, основанная на i18next, заключает экземпляр i18next в хранилище svelte и отслеживает события i18next, такие как languageChanged,..