Форум: "Базы";
Текущий архив: 2004.11.28;
Скачать: [xml.tar.bz2];
Внизмодификация данных из двух запросов в ADO Найти похожие ветки
← →
DimonNew (2004-11-02 18:27) [0]Привет, подскажите пож-та. Есть запрос:
select Key, Name, gtc_DayRemain, gtc_Key from Country
left outer join GorTurCountry on (gtc_Key=_Key)
order by Name
В Дельфи выводиться этот запрос в таблицу DBGrid с двумя столбцами Name и gtc_DayRemain. Как в данном случае модифицировать данные таблицы GorTurCountry используя ADO, при этом данные из таблицы tbl_Country менять нельзя? Или нельзя редактировать данные в ADOQuery, если он сосотоит из более олного запроса?
← →
msguns © (2004-11-02 18:38) [1]Возвращающий курсор TADOQuery не предназначен для редактирования.
← →
malamba (2004-11-02 18:48) [2]В реальности таблицы, получаемой в результате этого запроса, в базе не существует.
Данные напрямую изменить не удасться.
Что значит редактировать данные в ADOQuery?
Данные можно модифицировать при помощи UPDATE, INSERT и т.п.,
а таблица получается в результате запроса SELECT, который не влияет на набор данных.
В этом случае, ИМХО, нужно делать обработку событий DBGrid - а и в них уже вызывать UPDATE, INSERT и т.д.
← →
msguns © (2004-11-02 18:52) [3]>malamba (02.11.04 18:48) [2]
>В реальности таблицы, получаемой в результате этого запроса, в базе не существует.
Данные напрямую изменить не удасться.
Если под "напрямую" имеется в виду, что с помощью одного компонента, то неправда Ваша. Очень даже удастся. Правда только в одной (любой) таблице.
← →
DimonNew (2004-11-02 19:00) [4]Спасибо за подсказки.
← →
DimonNew (2004-11-02 19:01) [5]Спасибо за подсказки.
← →
AleKo (2004-11-03 03:13) [6]Пример работы через ADO c Access. Может получится и у Вас.
ADOData.ADODSSchOrg.Properties["Unique Table"].Value:="OrgSch"
Запрос с которым работаем
SELECT OrgSch.idOrgSch, OrgSch.idOrg, OrgSch.idSch, S_Schot.idBudg, S_Schot.Schot, S_BANK.BIK, S_BANK.SNAME
FROM (OrgSch LEFT JOIN S_Schot ON OrgSch.idSch = S_Schot.idSch) LEFT JOIN S_BANK ON S_Schot.idBank = S_BANK.idBnk;
← →
Lamo (2004-11-03 09:20) [7]Господи, какой бред! ([1],[2],[13)
Конечно можно редактировать такой recordset и даже более того - ADO будет обновлять данные во всех исходных таблицах, в которых сможет!
Беда в том, что ему очень трудно помешать это сделать:
http://www.sql.ru/forum/actualthread.aspx?tid=125696
← →
malamba (2004-11-03 10:38) [8]Время от времени полезно чувствовать себя полным чайником.
Не дает рассслабиться.
Lamo, дружище. Поклон Вам. Киньте ссылку на интересную нестандартную полную инфу об ADO. Если есть на родном языке - особое спасибо.
← →
Lamo (2004-11-03 11:38) [9]Блин, да сам не могу найти!
Во всяких популярных статьях типа (см. также предыдущ. и след. часть):
http://www.delphikingdom.com/asp/viewitem.asp?UrlItem=/helloworld/ado02.htm
все просто, а как столкнешься с чем-то чуть посложнее - и все, привет! И ищешь по крохам и сам эксперементируешь (типа, а теперь ты сверху а я снизу...)
Увы...
← →
malamba (2004-11-03 12:13) [10]Полностью солидарен...
Страницы: 1 вся ветка
Форум: "Базы";
Текущий архив: 2004.11.28;
Скачать: [xml.tar.bz2];
Память: 0.46 MB
Время: 0.035 c