Главная страница
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.039 c
9-89089
x_michael
2003-04-22 02:06
2003.10.27
DXSpriteEngine и прозрачность входящих туда Sprites


3-89105
Данила
2003-10-08 12:59
2003.10.27
Результаты в DBgrid.


8-89411
!ZasranYolidza!
2003-06-26 19:38
2003.10.27
bmp to jpg converting


7-89615
Opryshok
2003-07-16 19:53
2003.10.27
Горячие клавиши


6-89427
TButton
2003-08-30 20:15
2003.10.27
Asynchronous socket error 10054