Форум: "Базы";
Текущий архив: 2005.03.06;
Скачать: [xml.tar.bz2];
ВнизОшибка "Key violation" при выполнении запроса. Найти похожие ветки
← →
SHort (2005-02-04 16:27) [0]Есть база данных (таблицы в файлах dbf), доступ к которой роисходит через компоненты Table и Query. Перед каждой операцией с любой таблицей она (таблица) открывается, после операции - закрывается.
При выполнении Query.Open происходит вышеуказанная ошибка.
Подскажите, как с этим бороться?
← →
msguns © (2005-02-04 16:36) [1]Не открывать таблицу.
А если серьезно, то того, что в сабже, хватит только на подколки или для пищи желающим поупражняться в телепатии и ясновидении.
← →
msguns © (2005-02-04 16:41) [2]Не открывать таблицу.
А если серьезно, то того, что в сабже, хватит только на подколки или для пищи желающим поупражняться в телепатии и ясновидении.
← →
SHort (2005-02-04 16:56) [3]Если было любое обращение к таблице преред выполнением запроса - появляется эта ошибка, а если запрос выполняется первым - все ОК, ни каких ошибок.
← →
Соловьев © (2005-02-04 16:58) [4]
> Если было любое обращение к таблице преред выполнением запроса
> - появляется эта ошибка, а если запрос выполняется первым
> - все ОК, ни каких ошибок.
код приведи
← →
DSKalugin © (2005-02-04 17:00) [5]Если эта операция выборка то Query.Open
Если модифицирующий запрос (insert, update, delete)
тогда Query.ExecSQL
В хэлпе по TQuery ясно сказано
Call ExecSQL to execute the SQL statement currently assigned to the SQL property. Use ExecSQL to execute queries that do not return a cursor to data (such as INSERT, UPDATE, DELETE, and CREATE TABLE).
For SELECT statements, call Open instead of ExecSQL.
← →
DSKalugin © (2005-02-04 17:01) [6]Если эта операция выборка то Query.Open
Если модифицирующий запрос (insert, update, delete)
тогда Query.ExecSQL
В хэлпе по TQuery ясно сказано
Call ExecSQL to execute the SQL statement currently assigned to the SQL property. Use ExecSQL to execute queries that do not return a cursor to data (such as INSERT, UPDATE, DELETE, and CREATE TABLE).
For SELECT statements, call Open instead of ExecSQL.
← →
SHort (2005-02-04 17:03) [7]DM.DbKomun.Open;
DM.QDnevn.ParamByName("PDATR").AsDate:=R_DAT;
DM.QDnevn.Open; //Здесь ошибка
NewOperDnebnik.QuickRep1.Preview;
DM.QDnevn.Close;
DM.DbKomun.Close;
Сам запрос
SELECT SUMOP, DATOP, FIO, NSCH, WHAT, KBK, WHO, PROCPR, PROCKL, STORNO, SMEN, LSCHPOL, KBK, KPR, KCL
FROM OPERKOM Operkom
WHERE (STORNO IS NULL)
AND (DATOP = :PDATR)
ORDER BY NSCH
← →
Johnmen © (2005-02-04 17:11) [8]>SHort
Индексы поубивай и попробуй ещё раз...
← →
DSKalugin © (2005-02-04 18:33) [9]Переменная R_DAT правильно инициализируется?
попробуй так
DM.QDnevn.ParamByName("PDATR").AsDateTime
Страницы: 1 вся ветка
Форум: "Базы";
Текущий архив: 2005.03.06;
Скачать: [xml.tar.bz2];
Память: 0.46 MB
Время: 0.039 c