SQLRU.net
Разработка приложений баз данных

Начало » Использование СУБД » Firebird, HQbird, InterBase » Странность с исключениями в EB (Выколупано из теста на CORE-3029)
Странность с исключениями в EB [сообщение #5069] Fri, 17 May 2024 00:56 Переход к следующему сообщению
SD в настоящее время не в онлайне  SD
Сообщений: 357
Зарегистрирован: August 2022
Senior Member
Вот вводная:
create sequence test_gen;

recreate table test_row
(id int not null,
 did int not null,
 pid int not null,
 dep int not null
);
alter table test_row add constraint pk_test_row primary key(id);
create unique index ix_test_row1 on test_row(did, pid, dep);
commit;

insert into test_row(id, did, pid,dep) values(1, 2, 3, 4);
commit;
Вот собственно блок:
set term !!;
execute block returns(id int, did int, dep int, pid int)
as
declare variable xid int;
begin
  select id,did, pid,dep
    from test_row
   where id=(select min(id) from test_row)
    into :xid, :did, pid, :dep;

  while (1=1) do
  begin
    delete from test_row r where r.id = :xid;

    insert into test_row(id, did, dep, pid)
    values (gen_id(test_gen, 1), :did, :dep, :pid);

    suspend;

  when any do
    exception;
  end
end !!
Вопрос на засыпку: почему он перед ошибкой возвращает две строки?

Совершенно аналогичная процедура:
create or alter procedure sp_test
  returns(id int, did int, dep int, pid int)
as
declare variable xid int;
begin
  select id,did, pid,dep
    from test_row
   where id=(select min(id) from test_row)
    into :xid, :did, pid, :dep;

  while (1=1) do
  begin
    delete from test_row r where r.id = :xid;

    insert into test_row(id, did, dep, pid)
    values (gen_id(test_gen, 1), :did, :dep, :pid);

    suspend;

  when any do
    exception;
  end
end !!
select * from sp_test !!
Возвращает одну строку.

Чего я не понимаю?
Re: Странность с исключениями в EB [сообщение #5072 является ответом на сообщение #5069] Fri, 17 May 2024 11:41 Переход к предыдущему сообщениюПереход к следующему сообщению
hvlad в настоящее время не в онлайне  hvlad
Сообщений: 325
Зарегистрирован: August 2022
Senior Member
Смотри на значения генератора.
Re: Странность с исключениями в EB [сообщение #5075 является ответом на сообщение #5072] Fri, 17 May 2024 14:44 Переход к предыдущему сообщениюПереход к следующему сообщению
SD в настоящее время не в онлайне  SD
Сообщений: 357
Зарегистрирован: August 2022
Senior Member
А при чём здесь он, если идёт выброс нарушения уникальности ix_test_row1, а не pk_test_row?

Первый delete полностью очищает таблицу (поскольку в ней всего одна запись (1, 2, 3, 4)). Далее в неё пытаются вставиться (1, 2, 3, 4) и (2, 2, 3, 4) в EB. Первая вставка успешна, вторая вставка обламывается, транзакция полностью откатывается, восстанавливая запись (1, 2, 3, 4).

Последующий вызов процедуры снова удаляет запись (1, 2, 3, 4) и пытается вставить записи (3, 2, 3, 4) и (4, 2, 3, 4). Первая вставка успешна, вторая вставка обламывается, транзакция откатывается.

Так почему блок возвращает две записи, а процедура - одну?
Re: Странность с исключениями в EB [сообщение #5076 является ответом на сообщение #5075] Fri, 17 May 2024 15:57 Переход к предыдущему сообщениюПереход к следующему сообщению
hvlad в настоящее время не в онлайне  hvlad
Сообщений: 325
Зарегистрирован: August 2022
Senior Member
А ты всё же посмотри на значения генератора.

хинт1: выполни exec block два раза подряд
хинт2: в начальном скрипте используй генератор для инсерта
Re: Странность с исключениями в EB [сообщение #5079 является ответом на сообщение #5076] Fri, 17 May 2024 22:19 Переход к предыдущему сообщениюПереход к следующему сообщению
SD в настоящее время не в онлайне  SD
Сообщений: 357
Зарегистрирован: August 2022
Senior Member
Дошло.
Re: Странность с исключениями в EB [сообщение #5080 является ответом на сообщение #5079] Fri, 17 May 2024 22:33 Переход к предыдущему сообщению
hvlad в настоящее время не в онлайне  hvlad
Сообщений: 325
Зарегистрирован: August 2022
Senior Member
Не благодари
Предыдущая тема: Очищение старых данных в мультифайловой БД
Следующая тема: Внешние зависимости
Переход к форуму:
  


Текущее время: Sat Jun 01 09:33:51 GMT+3 2024

Общее время, затраченное на создание страницы: 0.00967 секунд