Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.01.14;
Скачать: CL | DM;

Вниз

добавление записи с если первичный индекс автоинкрементный   Найти похожие ветки 

 
victor   (2001-12-10 07:47) [0]

как добавить запись методом InsertRecord
что указывать в место счетчика


 
EsKor   (2001-12-10 09:18) [1]

По идее ничего не надо указывать.
По крайней мере, если используется DBNavigator и Table для работы с Paradox, проверено - по подтверждению или переходу на другую запись, значение в поле вносится автоматически.
Помнится экспериментировал с локальным сервером IBase, там создавался триггер на вставку (добавление) записи, то в SQL-запросе по созданию новой записи, это поле тоже указывать не нужно было.


 
victor   (2001-12-10 11:54) [2]

да с Table или просто с Query не надо
но мне приходится из-за сортировки использовать UpdateSQl
и при этом так не получается это поле так и остается пустым пока не закроешь и опять не откроешь прогу
или я что то не правильно делаю

кто работал с UpdateSql отзовитесь


 
Tonie ©   (2001-12-10 13:10) [3]

В это поле не вставляй ничего, а после вставки Refresh твой Query


 
victor   (2001-12-10 14:16) [4]

с помощью Refresh не получилось
а вот если
close
open
тогда все в порядке хотя вроде тоже самое :)


 
EsKor   (2001-12-11 04:52) [5]

Возможно, что в Вашем случае (первичный индекс автоинкрементный ) это единственная возможность нормально вставлять записи применяя пару:
close - open. Честно говоря я не понял с чем Вы работаете, но прочитал не помню в какой книге, что в механизме работы с SQL-серверами есть ошибка.
Состоит она в том, что при вставке новой записи сервер создает новое значение автонаращиваемого поля, но обратно в набор данных его не возвращает, соответственно возникает ошибка. Для обхода этой неприятности и применяется Close - Open. На IBase это проверено - так оно и есть, про остальные не знаю.


 
Deniz ©   (2001-12-11 07:00) [6]

Для IB можно написать процедуру, возвращающую след. ID, и для других серверов наверно.
А вообще, об этом была длинная дискуссия.



Страницы: 1 вся ветка

Текущий архив: 2002.01.14;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.011 c
4-42609
McSimm
2001-11-13 12:55
2002.01.14
Писать в запрещенные адреса памяти.


1-42445
Андре
2001-12-24 15:50
2002.01.14
Вопрос про компоненты


3-42365
csf
2001-12-10 16:28
2002.01.14
В Oracle есть dual, а что есть в InterBase e?


14-42551
Jey
2001-10-30 22:03
2002.01.14
ЗА СТЕКЛОМ


1-42435
Phisio
2001-12-24 15:01
2002.01.14
Выбор нескольких объектов