![]() |
|
|
Регистрация Восстановить пароль |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
![]() |
|
Опции темы | Поиск в этой теме |
![]() |
#1 |
Старожил
Регистрация: 05.06.2008
Сообщений: 4,210
|
![]()
Добрый вечер! Не могу уже второй день понять почему не работает код ниже. Нужно вот что сделать.
1. Получить номер последней записи в БД (сделано). 2. Передать в цикле параметры в хранимую процедуру и обновить одновременно указанную таблицу значениями, полученными после выполнения хранимой процедуры. Вот код: Код:
Код:
Раньше, подобный код работал на MS Access + Delphi. Сейчас перенес его в Firebird и не могу заставить работать. Код выше дает один из двух результатов: 1. Если я пишу так: Код:
2. Если пишу так: Код:
Не стоит смеяться над человеком делающим шаг назад, возможно он делает разбег.
|
![]() |
![]() |
![]() |
#2 |
Старожил
Регистрация: 17.11.2010
Сообщений: 18,922
|
![]()
1. Что-то хранимую процедуру не очень заметно
2. Вытащили из jurnal максимум ID, а потом пытаетесь обновить записи у котрых это ID больше максимального, естественно таких записей там нет
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию
|
![]() |
![]() |
![]() |
#3 |
Старожил
Регистрация: 05.06.2008
Сообщений: 4,210
|
![]() Код:
Код:
Не стоит смеяться над человеком делающим шаг назад, возможно он делает разбег.
|
![]() |
![]() |
![]() |
#4 |
Старожил
Регистрация: 17.11.2010
Сообщений: 18,922
|
![]() Код:
ADD Код:
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию
Последний раз редактировалось Аватар; 29.11.2011 в 16:55. |
![]() |
![]() |
![]() |
#5 | |
Старожил
Регистрация: 05.06.2008
Сообщений: 4,210
|
![]() Цитата:
Я почему повяз на max(ID)-то..мне не нужно в цикле обновлять все записи, это замедлит работу программы. Мне нужно обновить только последние добавленные записи. Вот, код, который прекрасно работал в связке MS Access + Delphi. Может так проще понять будет что мне нужно) Код:
![]()
Не стоит смеяться над человеком делающим шаг назад, возможно он делает разбег.
Последний раз редактировалось mihali4; 29.11.2011 в 18:47. |
|
![]() |
![]() |
![]() |
#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. |
|
![]() |
![]() |
![]() |
#7 | ||
Старожил
Регистрация: 05.06.2008
Сообщений: 4,210
|
![]() Цитата:
Цитата:
Не стоит смеяться над человеком делающим шаг назад, возможно он делает разбег.
|
||
![]() |
![]() |
![]() |
#8 |
Старожил
Регистрация: 17.11.2010
Сообщений: 18,922
|
![]()
Ну не вижу я в посте 1 где вы вставляете после того как запомнили максимальный ID. Запоминайте MAX(ID) перед вставкой
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию
|
![]() |
![]() |
![]() |
#9 |
Старожил
Регистрация: 05.06.2008
Сообщений: 4,210
|
![]()
Разобрался сегодня как должно было быть. Да, макс. айди надо было поставить перед кодом вставки новых записей. А код обновления должен выглядеть так:
Код:
![]()
Не стоит смеяться над человеком делающим шаг назад, возможно он делает разбег.
|
![]() |
![]() |
![]() |
![]() |
||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Цикл не работает | 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 |