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

Вниз

ADO. Не выполняются изменения в таблице   Найти похожие ветки 

 
well ©   (2008-02-19 14:00) [0]

Ну не совсем в таблице :).
В общем так. База MSSQL из 2 таблиц Table1,Table2 , соединяюсь с базой через компоненты ADO.
Использую компонент ADOQuery. Данные вывожу в DBGrid.

Запрос такой :
SELECT Table1.ID, Table1.Name
FROM Table1
INNER JOIN Table2 ON Table1.ID=Table2.ID


Во время выполнения программы я хочу внести изменения в поле Name. И всё получается!
Но если я чуть изменю запрос и добавлю в список запрашиваемых полей поле из второй таблицы:
SELECT Table1.ID, Table1.Name,Table2.Name
FROM Table1
INNER JOIN Table2 ON Table1.ID=Table2.ID

То при попытке изменить то же поле выдаётся ошибка: "Недостаточно сведений ключевого поля для обновления".
Можно ли выполнять изменения используя сложные запросы в качестве источника данных? (ну если исползовать выборку из полей только одной таблицы то можно).
Понятно, что изменения надо производить в таблице, а не в запросе, но почему в первом случае изменения выполняются?


 
Johnmen ©   (2008-02-19 14:18) [1]

Можно.
http://www.yandex.ru/yandsearch?text=%CD%E5%E4%EE%F1%F2%E0%F2%EE%F7%ED%EE+%F1%E2%E5%E4%E5%ED%E8%E9+%EA%EB%FE%F7%E5%E2%EE%E3%EE+%EF%EE%EB%FF+%E4%EB%FF+%EE%E1%ED%EE%E2%EB%E5%ED%E8%FF


 
well ©   (2008-02-19 16:15) [2]

Спасибо! Проблема оказывается известная.
У меня всё разрешилось введением для каждой таблицы primary key. И всё!


 
ANB   (2008-02-19 16:21) [3]


> введением для каждой таблицы primary key.

За таблицу без ПК надо отрывать руки.


 
Sergey13 ©   (2008-02-19 16:24) [4]

> [2] well ©   (19.02.08 16:15)

Я бы посоветовал осторожнее относиться к редактированию (особенно в гриде) "сложного" датасета, полученного из нескольких таблиц. Можно поиметь неприятные неожиданности.



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

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

Наверх




Память: 0.47 MB
Время: 0.011 c
2-1215060368
Alex_C
2008-07-03 08:46
2008.08.03
Перестал работать компонент


2-1215089682
Кирей
2008-07-03 16:54
2008.08.03
ошибка в вычисляемом поле


2-1215040775
Si13
2008-07-03 03:19
2008.08.03
VSL Form, проблемы с открытием


2-1215360644
observateur
2008-07-06 20:10
2008.08.03
widestring


4-1193654690
Dmitry_177
2007-10-29 13:44
2008.08.03
почему не срабатывает таймер?