Главная страница
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.042 c
14-1107783991
Piter
2005-02-07 16:46
2005.03.06
Что вы настраиваете после установки WinXP?


3-1107786978
Abusss
2005-02-07 17:36
2005.03.06
ADO+фильтр


6-1104081220
Delta
2004-12-26 20:13
2005.03.06
запуск ехе на чужом компе


1-1108668519
Redhopter
2005-02-17 22:28
2005.03.06
Приведение типов


14-1108508807
GanibalLector
2005-02-16 02:06
2005.03.06
Обзор решений для магазина супермаркета