Главная страница
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.015 c
6-89450
kopcap
2003-09-02 13:32
2003.10.27
Работа с файлами...


7-89628
Sheng
2003-08-14 23:03
2003.10.27
Каталог Винды


7-89627
Евгыш
2003-08-15 17:32
2003.10.27
Работа с сенсорным экраном


1-89391
RoLeX
2003-10-15 12:17
2003.10.27
Как убрать из панели задач мою программу??


1-89298
CacheMeM
2003-10-13 08:24
2003.10.27
Turbo Pascal 7.0 Compiler