|
|
Регистрация Восстановить пароль |
Повторная активизация e-mail |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
Опции темы | Поиск в этой теме |
29.11.2011, 16:23 | #1 |
Старожил
Регистрация: 05.06.2008
Сообщений: 4,206
|
Не работает цикл обновления в Firebird
Добрый вечер! Не могу уже второй день понять почему не работает код ниже. Нужно вот что сделать.
1. Получить номер последней записи в БД (сделано). 2. Передать в цикле параметры в хранимую процедуру и обновить одновременно указанную таблицу значениями, полученными после выполнения хранимой процедуры. Вот код: Код:
Код:
Раньше, подобный код работал на MS Access + Delphi. Сейчас перенес его в Firebird и не могу заставить работать. Код выше дает один из двух результатов: 1. Если я пишу так: Код:
2. Если пишу так: Код:
Не стоит смеяться над человеком делающим шаг назад, возможно он делает разбег.
|
29.11.2011, 16:34 | #2 |
Старожил
Регистрация: 17.11.2010
Сообщений: 18,922
|
1. Что-то хранимую процедуру не очень заметно
2. Вытащили из jurnal максимум ID, а потом пытаетесь обновить записи у котрых это ID больше максимального, естественно таких записей там нет
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию
|
29.11.2011, 16:42 | #3 |
Старожил
Регистрация: 05.06.2008
Сообщений: 4,206
|
Код:
Код:
Не стоит смеяться над человеком делающим шаг назад, возможно он делает разбег.
|
29.11.2011, 16:46 | #4 |
Старожил
Регистрация: 17.11.2010
Сообщений: 18,922
|
Код:
ADD Код:
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию
Последний раз редактировалось Аватар; 29.11.2011 в 16:55. |
29.11.2011, 17:58 | #5 | |
Старожил
Регистрация: 05.06.2008
Сообщений: 4,206
|
Цитата:
Я почему повяз на max(ID)-то..мне не нужно в цикле обновлять все записи, это замедлит работу программы. Мне нужно обновить только последние добавленные записи. Вот, код, который прекрасно работал в связке MS Access + Delphi. Может так проще понять будет что мне нужно) Код:
Не стоит смеяться над человеком делающим шаг назад, возможно он делает разбег.
Последний раз редактировалось mihali4; 29.11.2011 в 18:47. |
|
29.11.2011, 18:21 | #6 | |
Старожил
Регистрация: 17.11.2010
Сообщений: 18,922
|
В этом коде вы работаете с каким то max. Я так понял, что в какой то момент вы запоминаете MAX(id), далее идет вставка новых записей и потом работает приведенный кусок кода. Он и будет править последние вставленные записи, у которых id>max. А в первом коде вы сразу выдернули MAX(id) и не вставляя новых записей, пытаетесь обновить то, чего нет. И явное завершение транзакции (Commit) в том контексте мне не понятно. А где явное начало транзакции (Begin Transaction)? И если уж использовать такие вещи явно, то и Rollback в случае ошибки обращения к базе нужно предусматривать. Это по опыту работы на MS SQL, думаю и firebird не очень в этом смысле отличается
Цитата:
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию
Последний раз редактировалось Аватар; 29.11.2011 в 18:25. |
|
29.11.2011, 18:58 | #7 | ||
Старожил
Регистрация: 05.06.2008
Сообщений: 4,206
|
Цитата:
Цитата:
Не стоит смеяться над человеком делающим шаг назад, возможно он делает разбег.
|
||
29.11.2011, 19:47 | #8 |
Старожил
Регистрация: 17.11.2010
Сообщений: 18,922
|
Ну не вижу я в посте 1 где вы вставляете после того как запомнили максимальный ID. Запоминайте MAX(ID) перед вставкой
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию
|
30.11.2011, 17:08 | #9 |
Старожил
Регистрация: 05.06.2008
Сообщений: 4,206
|
Разобрался сегодня как должно было быть. Да, макс. айди надо было поставить перед кодом вставки новых записей. А код обновления должен выглядеть так:
Код:
Не стоит смеяться над человеком делающим шаг назад, возможно он делает разбег.
|
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Цикл не работает | Faridik | Общие вопросы по Java, Java SE, Kotlin | 1 | 14.08.2011 12:14 |
скрит работает в interbase а в FireBird выдает ошибку | NikK1 | БД в Delphi | 9 | 13.04.2010 18:07 |
Не работает цикл | Lisёноk | Помощь студентам | 5 | 23.03.2010 21:39 |
Цикл не работает | doniyor | Общие вопросы Delphi | 1 | 06.12.2009 15:52 |
Цикл не работает...? | Иринкаа | Помощь студентам | 6 | 17.11.2007 00:27 |