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

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

05.07.2009, 12:37. Просмотров 5862. Ответов 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
05.07.2009, 12:37
Ответы с готовыми решениями:

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

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

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

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

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

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

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

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

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

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;
}
1
Вложения
Тип файла: zip ImageConverter_src.zip (1.6 Кб, 92 просмотров)
0 / 0 / 0
Регистрация: 05.07.2009
Сообщений: 3
07.07.2009, 14:44  [ТС] 5
Проблема не преобразовать данные, а сохранить.

НЕ пишется массив в датабазу.
0
Roberto1
20.12.2012, 18:25 6
Долго мучился, в итоге запись и чтение сделал через 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]);
у меня так и не вышло нормальные данные вытащить.
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
20.12.2012, 18:25

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь или здесь.

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

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


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.