Форум программистов, компьютерный форум, киберфорум
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. Показов 10408. Ответов 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
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru