Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как из Делфи создать базу данных Access 
:(
    Опции темы
Sponger
Дата 14.4.2006, 13:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 165
Регистрация: 14.2.2006

Репутация: нет
Всего: нет



У меня есть база данных Access. Все таблицs в ней имеют логическое поле New.
Как создать такую-же БД только чтобы во всех таблицах были только записи у которых New = TRUE

Это сообщение отредактировал(а) Sponger - 14.4.2006, 13:20
PM MAIL   Вверх
bas
Дата 14.4.2006, 14:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 446
Регистрация: 14.8.2002
Где: Молдова, Кишинев

Репутация: 1
Всего: 2



Два запроса
Create table
и
insert into
PM MAIL   Вверх
Sponger
Дата 14.4.2006, 14:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 165
Регистрация: 14.2.2006

Репутация: нет
Всего: нет



Мне нужно создать базу данных (новый файл .mdb), а не таблицу.
PM MAIL   Вверх
Savek
Дата 14.4.2006, 15:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 355
Регистрация: 10.4.2006
Где: Воронеж

Репутация: 7
Всего: 7



Базу создать так:
Код

procedure CreateMSAccessDB(filename : String);
var
  DBEngine, Workspace: Variant;
const
  {Important to use the following constant as is}
  dbLangGeneral = ';LANGID=0x0409;CP=1252;COUNTRY=0';
  dbVersion30 = 64;
begin
if not FileExists(FileName+'.mdb') then begin
  //DBEngine := CreateOleObject('DAO.DBEngine');
  DBEngine := CreateOleObject('DAO.DBEngine.36'); //For DAO 3.5
  Workspace := DBEngine.Workspaces[0];
  try
    Workspace.CreateDatabase(filename, dbLangGeneral, dbVersion30);
  except on EOleException do
    ShowMessage('Database already exists');
  end;
  end;
end;


А таблицы скопировать запросом

Select * into Table from Table in "путь к старой базе"
PM MAIL   Вверх
Sponger
Дата 14.4.2006, 15:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 165
Регистрация: 14.2.2006

Репутация: нет
Всего: нет



Этот пример создает базу в формате Access 95, а мне надо 2000 или выше.
Но с этим разобрался. Создаю базу вот так.

Код

var cat: OLEVariant;
begin
  Result := '';
  try
    cat := CreateOleObject('ADOX.Catalog');
    cat.Create('Provider=Microsoft.Jet.OLEDB.4.0;Data Source=' + FileName + ';');
    cat := NULL;
  except
    on e: Exception do Result := e.message;
  end;


Цитата

Select * into Table from Table in "путь к старой базе"


За это спасибо. Я думал запрос можно делать только в пределах одной базы данных.

PM MAIL   Вверх
Sponger
Дата 15.4.2006, 09:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 165
Регистрация: 14.2.2006

Репутация: нет
Всего: нет



Помогите написать правильно
я пишу
Код

SendCommand.CommandText := 'SELECT * INTO table FROM table IN "" [ACCESS; DATABASE=:database;] WHERE [new] = TRUE';
sendCommand.Parameters.ParseSQL(SendCommand.CommandText, TRUE);
sendCommand.Parameters.ParamValues['database'] := полный_путь_к_базе\название_базы;
sendCommand.execute;


Он мне пишет ошибку
Project xxx raised exception class EOleException with message "Невозможно найти устанавливаемый ISAM". ...

Это сообщение отредактировал(а) Sponger - 15.4.2006, 09:25
PM MAIL   Вверх
Savek
Дата 15.4.2006, 11:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 355
Регистрация: 10.4.2006
Где: Воронеж

Репутация: 7
Всего: 7



Подключение к старой базе прописываешь в ConnectionString компонента
А сам запрос может выглядеть так:
Код

select * into NewTable in "C:\Моя база\BaseName.mdb" from OldTable where New


Вместо NewTable и OldTable ставь реальные имена таблиц
PM MAIL   Вверх
Vit
Дата 16.4.2006, 02:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Vitaly Nevzorov
****


Профиль
Группа: Экс. модератор
Сообщений: 10964
Регистрация: 25.3.2002
Где: Chicago

Репутация: 14
Всего: 207



проще всего этот вопрос решается к подшиванию нужного mdb файла как ресерса к exe и извлечение его в файл при необходимости


--------------------
With the best wishes, Vit
I have done so much with so little for so long that I am now qualified to do anything with nothing
Самый большой Delphi FAQ на русском языке здесь: www.drkb.ru
PM MAIL WWW ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.0647 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.