Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.84/37: Рейтинг темы: голосов - 37, средняя оценка - 4.84
0 / 0 / 0
Регистрация: 05.07.2009
Сообщений: 3

Вложение Attach в Access 2007 accdb. Как его добавить в БД

05.07.2009, 12:37. Показов 7341. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте специалисты.
пишу програмку на С# - надо в базу данных, кроме всяческих имен и цифорок, сохранить массив данных. бинарный, например картинку.

перлелопатил инет, ничего ненашел.
нашел как считать данные, записанные заранее в базу, например из самого access.
использую Provider=Microsoft.ACE.OLEDB.12.0;

это пример как прочитать картинку заранее записанную, работает на ура.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
OleDbConnection conn = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=|DataDirectory|\WWS_BD_Data.accdb;Persist Security Info=True");
                 OleDbCommand cmd = new OleDbCommand("select DATABIN.filedata, DATABIN.filename, DATABIN.filetype from DataArray WHERE ID = @ID", conn);
                 cmd.Parameters.Add(new OleDbParameter("@ID", 1));
                 conn.Open();
                 try
                 {
                     OleDbDataReader dr = cmd.ExecuteReader();
                     while (dr.Read())
                     {
                         data = ParseImageData((byte[])dr[0]);
                         stream = new MemoryStream(data);
                         fileType = dr[2].ToString().ToUpper();
                    
                      }
                
                 }
                 finally
                 {
                     conn.Close();
                 };

изходя из предыдущего. пытаюсь по аналогии сделать запись. хрен. непишет и все.
притом не пишет именно данные. если оставить только имя файла. то пишется, только с нулевой длинной файла. пробовал менять тип данных, непомогает. пробовал сделать update set, и все равно данные не пишутся.

вот попытка.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Byte[] fileData = new Byte[fs.Length];
 
 
 
 OleDbConnection conn = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=|DataDirectory|\WWS_BD_Data.accdb;Persist Security Info=False");
            OleDbCommand cmd = new OleDbCommand("insert into DataArray (DATABIN.filename,DATABIN.FileData) VALUES(@filename,@filedata) WHERE Код = @Код", conn);
            cmd.Parameters.Add(new OleDbParameter("@filename", dinn.ToString() + "arr.bin"));
            cmd.Parameters.Add(new OleDbParameter("@filedata", fileData));
            cmd.Parameters.Add(new OleDbParameter("@Kod", dinn));
                          
            
           conn.Open();
 
 
           try
           {
               cmd.ExecuteNonQuery(); 
           }
            finally
            {
                conn.Close();
            };

в инете много примеров под OLEDB.4. а под OLEDB.12 нету. или я не там ищу. на мсдн искал, описание записи в аттачмент не нашел. чтение есть.

Прошу помощи, расскажите как сохранить файлик. или дайте ссылку на рабочий пример.
всех благ.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.07.2009, 12:37
Ответы с готовыми решениями:

Подключение БД Access 2007 (*.accdb)
Подключите пожалуйста данную БД http://rghost.ru/52932806 к делфям, и передайте сохранённый проект, со всеми файлами, очень прошу...

Работа с Access 2007 (.accdb)
Есть программа, работающая с базой данных через dataset,datagridview Подключение к базе создается здесь:public Form1() { ...

Access 2007 accdb известный пароль не возможно сменить или убрать
Коллеги, кто знает, помогите пожалуйста. Странная ситуация с любимой базой, которую веду больше трех лет. Столкнулся с проблемой замены...

5
Комбайнёр
 Аватар для MAcK
1606 / 704 / 77
Регистрация: 27.05.2008
Сообщений: 2,535
05.07.2009, 18:02
Нужно саму картинку перевести в масив байтов и затем сохранить в поле типа BLOB, при считывании масив опять перевести в имадж, но это плохой стиль программирования, так как при попытке найти какую-то запись, уже при размере 1000 строк, в каждой строке есть 30 кб картинки, будет сильно тормозить. Если БД не будет перемещаться или есть возможность копировать папку вместе с БД, то лучше сохранить путь к файлу и при считывании строки, читывать сам файл.
к примеру путь "\Pic\MyPic.jpg" означает, что файл находится впапке Pic, а папка находится на одном уровне с ехе.
0
0 / 0 / 0
Регистрация: 05.07.2009
Сообщений: 3
06.07.2009, 00:46  [ТС]
BLOB как я понял это массив байтов.

я в нерабочем примере так и делаю. пишу

C#
1
Byte[] fileData = new Byte[fs.Length];
потом я его забиваю данные. за ненадобностью тут, я это вытер.

и пытаюсь записать

C#
1
cmd.Parameters.Add(new OleDbParameter("@filedata", fileData));
и непишется. ругается --ошибочный аргумент.
0
Комбайнёр
 Аватар для MAcK
1606 / 704 / 77
Регистрация: 27.05.2008
Сообщений: 2,535
06.07.2009, 08:25
В массив байт

C#
1
2
3
4
5
6
public byte[] imageToByteArray(System.Drawing.Image imageIn)
{
 MemoryStream ms = new MemoryStream();
 imageIn.Save(ms,System.Drawing.Imaging.ImageFormat.Gif);
 return  ms.ToArray();
}
в имадж

C#
1
2
3
4
5
6
public Image byteArrayToImage(byte[] byteArrayIn)
{
     MemoryStream ms = new MemoryStream(byteArrayIn);
     Image returnImage = Image.FromStream(ms);
     return returnImage;
}
Вложения
Тип файла: zip ImageConverter_src.zip (1.6 Кб, 94 просмотров)
1
0 / 0 / 0
Регистрация: 05.07.2009
Сообщений: 3
07.07.2009, 14:44  [ТС]
Проблема не преобразовать данные, а сохранить.

НЕ пишется массив в датабазу.
0
Roberto1
20.12.2012, 18:25
Долго мучился, в итоге запись и чтение сделал через Microsoft.Office.Interop.Access.Dao
код специально оставил целым, тут и авторизация с паролем тоже пришлось искать.
использую:Microsoft.ACE.OLEDB.12.0;

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
            DBEngine dbe = new DBEngine();
            Database db = dbe.OpenDat abase(MyConfiguration.ConnectionString.Replace("Provider = Microsoft.ACE.OLEDB.12.0; Data Source = ", ""), false, false,
                string.Format("MS Access;PWD={0}", MyConfiguration.pas));
            Recordset rs = db.OpenRecordset(string.Format("SEL ECT CompanyParams.[ID], CompanyParams.[ParamName], CompanyParams.[ParamDescription], " +
                "CompanyParams.[ParamFiles], CompanyParams.[ParamFiles].[FileData] as FileData, [ParamFiles].[FileFlags] AS FileFlags, " +
                "CompanyParams.[ParamFiles].[FileName] AS FileName , [ParamFiles].[FileTimeStamp] AS FileTimeStamp, " +
                "CompanyParams.[ParamFiles].[FileType] AS FileType, [ParamFiles].[FileURL] AS FileURL, " +
                "CompanyParams.[CompanyID] AS CompanyID FR OM CompanyParams Where CompanyParams.[CompanyID]={0};", CompanyID),
                RecordsetTypeEnum.dbOpenDynaset, 0, LockTypeEnum.dbOptimistic);
            //rs.MoveFirst();
            rs.AddNew();
 
            Field2 f2 = (Field2)rs.Fields["FileData"];
            f2.LoadFromFile(fileName);
            rs.Fields["CompanyID"].Value = CompanyID;
            rs.Fields["ParamName"].Value = ParamName;
            rs.Fields["ParamDescription"].Value = ParamDescription;
            rs._30_Update();
            rs.Close();
считывать тоже оказалось можно так
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
            DBEngine dbe = new DBEngine();
            Database db = dbe.OpenDat abase(MyConfiguration.ConnectionString.Replace("Provider = Microsoft.ACE.OLEDB.12.0; Data Source = ",""), false, false,
                string.Format("MS Access;PWD={0}", MyConfiguration.pas));
            Recordset rs = db.OpenRecordset(string.Format("SELECT CompanyParams.[ID], CompanyParams.[ParamName], CompanyParams.[ParamDescription], " +
                "CompanyParams.[ParamFiles], CompanyParams.[ParamFiles].[FileData] as FileData, [ParamFiles].[FileFlags] AS FileFlags, " +
                "CompanyParams.[ParamFiles].[FileName] AS FileName , [ParamFiles].[FileTimeStamp] AS FileTimeStamp, " +
                "CompanyParams.[ParamFiles].[FileType] AS FileType, [ParamFiles].[FileURL] AS FileURL, " +
                "CompanyParams.[CompanyID] AS CompanyID FR OM CompanyParams Wh ere CompanyParams.[ID]={0};",CompanyParamsId), 
                RecordsetTypeEnum.dbOpenDynaset, 0, LockTypeEnum.dbOptimistic);
            rs.MoveFirst();
            Field2 f2 = (Field2)rs.Fields["FileData"];
 
            f2.SaveToFile(fileName);
 
            
            rs.Close();
могли приложить свою функцию
C#
1
data = ParseImageData((byte[])dr[0]);
у меня так и не вышло нормальные данные вытащить.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.12.2012, 18:25
Помогаю со студенческими работами здесь

Как добавить фаил в поле Вложение MS Access средствами C#
Помогите, пожалуйста! Необходимо добавить любой фаил в поле вложение MS Access. Много уже обыскал информации по этой теме. Выяснил, что...

Как добавить сразу всю таблицу в форму (Access 2007)?

Как поставить QuickReport для Builder 2007 и добавить его в компоненты на панель
Ребят, подскажите пожалуйста как поставить QuickReport для 2007 Билдере, ну и добавить его в компоненты на панель, очень надо( в...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru