Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2003.09.04;
Скачать: [xml.tar.bz2];

Вниз

АDO и ACCESS   Найти похожие ветки 

 
Петр   (2003-08-08 05:10) [0]

Добрый день, уважаемые знатоки !

Есть такая проблема: Стоит задача импорта данных из одного mdb файла в другой. При помощи каких компонент АDO это можно сделать?

Проблема заключается в том, что Query подключается только к одному ADOConnection, к которому, в свою очередь, можно подключить только один файл mdb.

Запрос SQL, для перекачки данных я составил, но как реализовать подключение к Query двух файлов mdb?, посколько сам запрос предполагает обращение к таблицам, находящимся в разных физических файлах.


 
SPIRIT   (2003-08-08 06:25) [1]

Два TAdoConnection нельзя на одну форму кинуть что ли ?


 
Петр   (2003-08-08 06:44) [2]

Я так и сделал. Кинул 2 TADOConnection, подключил каждый к своему mdb, подключил каждый файл к ADOTable, но дело все в том, что мы получаем 2 набора данных, а как SQL будет воспринимать эти наборы? Или я чего-то не допонимаю? Как мне в SQL запросе обратиться в двум этим разным файлам?


 
Stas   (2003-08-08 07:16) [3]

А если сначала скопировать куда-то данные из одной базы, потом переключиться на другой ADOConnection и добавить данные оттуда куда ты их временно кинул?


 
sniknik   (2003-08-08 08:18) [4]

не надо два конекта, одного вполне достаточно, для нешних данных используется IN в запросах. (SELECT INTO ..., INSERT INTO....)
можно даже обьеденение и общий запрос с несколькими базами построить.

из хелпа

Предложение IN
Определяет таблицы в любой внешней базе данных, с которой ядро базы данных Microsoft Jet может установить связь, например в базе данных dBASE, Paradox или внешней базе данных с ядром Microsoft® Jet.

Синтаксис
Чтобы определить результирующую таблицу:

[SELECT | INSERT] INTO назначение IN
{путь | ["путь" "тип"] | ["" [тип; DATABASE = путь]]}

Чтобы определить исходную таблицу:

FROM выражение IN
( по отношению к текущему коннекту) не надо два конекта, одного вполне достаточно, для нешних данных используется IN в запросах. (SELECT INTO ..., INSERT INTO....)
можно даже обьеденение и общий запрос с несколькими базами построить.

из хелпа

Предложение IN
Определяет таблицы в любой внешней базе данных, с которой ядро базы данных Microsoft Jet может установить связь, например в базе данных dBASE, Paradox или внешней базе данных с ядром Microsoft® Jet.

Синтаксис
Чтобы определить результирующую таблицу:

[SELECT | INSERT] INTO назначение IN
{путь | ["путь" "тип"] | ["" [тип; DATABASE = путь]]}

Чтобы определить исходную таблицу:

FROM выражение IN
{путь | ["путь" "тип"] | ["" [тип; DATABASE = путь]]}


пример открытия таблици из внешней(по отношению к текущему коннекту) базы
SELECT * FROM TableName IN "D:\ExternBase.mdb"


 
malamba   (2003-08-08 14:42) [5]

А если у него строки соединения разные, т.е. два разных TADOConnection?
Но все равно проблем быть не должно - два соединеия, два DataSet, а запросы передаются каждый своему набору данных


 
sniknik   (2003-08-09 14:46) [6]

malamba (08.08.03 14:42)
> А если у него строки соединения разные, т.е. два разных TADOConnection?
а с двумя конектами общих запросов не получится, только на уровне движка соеденяются. именно для этого и есть поддержка.


 
Hawk2   (2003-08-09 17:51) [7]

Если полей не очень много то можно еще одним способом, хоть и корявым, но все же вариант. Открываешь одну таблицу c помощью Query, а вторую с через Table. В первой выбираешь то что тебе нужно и потом в цикле:
While not Query.EOF do
begin
Table.Append;
Table.FieldByName("SomeField").AsSomeType:=Query.FieldByName ("SomeField").AsSomeType;
Table.Next;
end;
Вроде бы так.


 
Um   (2003-08-12 06:39) [8]


> sniknik

Клёво, давно искал, и главное просто



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

Форум: "Базы";
Текущий архив: 2003.09.04;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.015 c
1-10736
Zed
2003-08-20 09:45
2003.09.04
Rак сохранить изображение целой формы


8-10841
nevalex
2003-05-08 09:17
2003.09.04
Как нарисавать функцию


7-11006
BlackSun
2003-06-20 03:36
2003.09.04
Импорт данных (телефон, пароль)


14-10963
Омлет
2003-08-16 23:58
2003.09.04
Именинники 17 августа !


3-10582
korvin
2003-08-14 09:25
2003.09.04
---|Ветка была без названия|---





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский