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

Вниз

Ошибка   Найти похожие ветки 

 
RealShip   (2003-10-08 15:16) [0]

Есть форма, на ней DBGridEh, есть ADOQuery, dataset которого привязана к гриду.
Выполняется запрос: query:="SELECT A.*,B.* FROM Main as B INNER JOIN Employees as A ON A.Code=B.FIO WHERE B.Month=" + IntToStr(MonthOf(MonthC.Date)) + " AND B.Year=" + IntToStr(YearOf(MonthC.Date));

При попытке обновить таблицу через
With FmMain.DBGrid.DataSource.DataSet do
begin
Edit;
FieldByName("Hours").AsFloat:=StrToFloat(EHours.Text);
FieldByName("Percents").AsFloat:=StrToFloat(EPercents.Text);
FieldByName("KTU").AsFloat:=StrToFloat(EKtu.Text);
Post;
end;
вылезает ошибка "Insufficient Base Table Information for Updating".

Помогите разобраться! Спасибо!


 
sniknik ©   (2003-10-08 15:26) [1]

скорее всего ключа у таблице нет, сделай ключевое поле, попробуй с ним.


 
RealShip   (2003-10-08 15:42) [2]

спасибо за ответ!
Сам уже разобрался: эта ошибка выскакивает тока на компах где стоит Win98 (на ХР все ок).
Оказывается, что нужно явно указывать имена таблиц в запросе, а не использовать комбинацию Main as B,Employees as A...
То есть: query:="SELECT Employees.*,Main.* FROM Main INNER JOIN Employees ON Employees.Code=Main.FIO WHERE Main.Month=" + IntToStr(MonthOf(MonthC.Date)) + " AND Main.Year=" + IntToStr(YearOf(MonthC.Date));



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

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

Наверх




Память: 0.47 MB
Время: 0.019 c
6-89428
Akim2
2003-08-29 15:34
2003.10.27
MAC при отключении из сети


1-89261
AlexanderSK
2003-10-14 17:29
2003.10.27
Как сохранить строку в TFileStrem


1-89201
REP
2003-10-15 11:54
2003.10.27
Файлы без расширения и OpenDialog


1-89380
I'm lamer
2003-10-15 18:00
2003.10.27
SynEdit


1-89314
Иванько
2003-10-15 18:32
2003.10.27
Проблема у RichEdit под WinXP