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

Вниз

Ошибка "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;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.052 c
1-1108823266
Коля
2005-02-19 17:27
2005.03.06
есть StringGrid. как выделить текст в одной из ячеек програмно?


14-1108457078
Franzy
2005-02-15 11:44
2005.03.06
Не ставится Win98


4-1106308683
SvarogBarg
2005-01-21 14:58
2005.03.06
Как получить URL адрес


1-1109094012
read_me
2005-02-22 20:40
2005.03.06
помогите пожалуйста разобраться и переделать


6-1103822762
Alexey Romanskiy
2004-12-23 20:26
2005.03.06
Как узнать свой ай-пишник?