Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/50: Рейтинг темы: голосов - 50, средняя оценка - 4.64
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1

Создание файла базы данных Access. Нужно создать программно. Покажите как, ничего не нашёл.

08.06.2011, 02:36. Показов 10400. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Долго гуглил, ничего вразумительного не нашёл. Находил как можно создать файл базы данных подключив какую-то библиотеку ADOX, только я что-то не понял, зачем её использовать? Что без неё никак? Покажите, как создать базу или объясните почему надо использовать этот ADOX.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.06.2011, 02:36
Ответы с готовыми решениями:

Как программно удалить таблицу из базы данных Access?
Как в базе данных MS Access удалить таблицу программно???:help:

Как добавлять записи в таблицу базы данных Access программно через ADO?
Как добавлять записи в таблицу базы данных Access программно через ADO?:yahoo:

Как создать базу данных (Access) программно
Может ли кто подсказать, как создать БД (Access) программно? P.S. Рыскал поиск - но ничего не нашёл :(

11
334 / 270 / 18
Регистрация: 19.01.2011
Сообщений: 597
08.06.2011, 10:35
Наверное, потому что в ADO.NET (как встречал на одном из сайтов - он создан для доступа к данным, а не для создания самих баз) нет средств для создания базы. А в ADOX -есть. И судя по всему - майкрософт рекомендует использовать adox на свой страх и риск в приложениях .net. Нужно ли это? проще себе в ресурсы засунуть пустую сжатую базу Access а при необходимости доставать ее оттуда и сохранять под новым именем.
1
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1
08.06.2011, 11:00  [ТС]
Вот вот, я тоже подумал "таскать" с собой готовую пустую базу данных и при необходимости копировать куда надо. Но вот про ресурсы вообще не подумал. Так наверное даже лучше. То есть я сейчас запущу Office Access 2007, создам базу, сохраню в ресурсы, потом смогу её копировать куда угодно и работать с ней? И кстати у базы должно быть расширение accdb? Просто видел другое расширение в одном примере.
0
334 / 270 / 18
Регистрация: 19.01.2011
Сообщений: 597
08.06.2011, 11:27
Да. Выбирайте тип в свойствах файла Resource .В книге WPF 4 Unleashed
Adam Nathan есть глава про Binary Resources, читать можно например так. Ну или так
C#
1
config.Properties.Resources.image.Save("C:/image.jpg");
1
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1
08.06.2011, 11:36  [ТС]
У меня почему-то создаётся не *.mdb, а *.accdb. Это нормально? В Office Access 2007.
0
334 / 270 / 18
Регистрация: 19.01.2011
Сообщений: 597
08.06.2011, 11:47
Да. по умолчанию для 2007 Access - это новый формат баз данных. Можете создать и mdb, выбрав формат баз данных, совместимый с Access 2003. Если Вы создаете с помощью ADOX - не подскажу, не пользовался им, надо ковырять по поводу совместимости с 2003.
0
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1
08.06.2011, 12:03  [ТС]
Нет, я не буду пользоваться ADOX. Создал уже такого формата.

Что-то не пойму. Извлекаю базу данных так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
            CopyDatabaseFromResource(Path.Combine(App.ApplicationPath, "Database.accdb"));
        }
 
        private void CopyDatabaseFromResource(String destinationPath)
        {
            Uri uri = new Uri(@"pack://application:,,,/Resources/Data.accdb", UriKind.Absolute);
            StreamResourceInfo sri = Application.GetResourceStream(uri);
            byte[] byteResource = new byte[sri.Stream.Length];
            using (FileStream fs = new FileStream(destinationPath, FileMode.CreateNew, FileAccess.Write))
            {
                fs.Write(byteResource, 0, byteResource.Length);
            }
        }
    }
И в папку с программой извлекается база, но при её открытии Office Access 2007 показывает ошибку:
"Нераспознаваемый формат базы данных (тут путь к этому файлу)"
0
334 / 270 / 18
Регистрация: 19.01.2011
Сообщений: 597
08.06.2011, 13:13
Хм. Все работает... в аттаче пример проекта. Добавлял базу так - правой клавишей на солушене - свойства, там ресурсы, тип ресурсов файл, добавить существующий. На файле, который добавился в солушен - тип Ресурс, Не копировать в дестфолдер. после этого в Resources.Designer.cs появляется проперти, возвращающее byte[] для данного файла.
0
334 / 270 / 18
Регистрация: 19.01.2011
Сообщений: 597
08.06.2011, 13:14
Опять аттач отвалился
Вложения
Тип файла: 7z EmbedAccessDB.7z (38.4 Кб, 105 просмотров)
0
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1
08.06.2011, 18:35  [ТС]
Всё тут разобрался
0
334 / 270 / 18
Регистрация: 19.01.2011
Сообщений: 597
08.06.2011, 18:49
Да пожалуйста. У меня код получается компактнее немного
0
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1
08.06.2011, 19:37  [ТС]
Цитата Сообщение от Winsor Посмотреть сообщение
Да пожалуйста. У меня код получается компактнее немного
У меня WPF проект, там получить ресурсы таким способом у меня не получилось.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.06.2011, 19:37
Помогаю со студенческими работами здесь

Как программно создать File Resource в дизайне базы данных?
Всем привет Есть элемент базы данных - File Resource. Туда можно добавлять файлы произвольного содержания. Как это можно сделать...

Как программно создать базу данных Access и таблицы в ней на Delphi
Как программно создать базу данных Access и таблицы в ней на Delphi

Создание базы данных, открытие из под одной базы данных MS Access
Здравствуйте. В общем, C# начал заниматься только вот и сразу была поставлена задача создать базу данных. Идея есть, при открытие программы...

Как в Delphi программно создать БД не устанавливая ничего
Здравствуйте, есть такая задача. Нужно чтобы программа на delphi. Сома создавало базу данных и использовало её. При этом пользователь...

Где же файл базы данных MSSQL? Как его создать, чтобы потом переносить вместе с Access на другой ПК? Как подключить?
Здравствуйте! Никак не могу разобраться с MSSQL. Базу данных в ней уже создавать умею. Подключал Access к ней. Но моё приложение должно...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru