Опять DAO...теперь в картинках

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
Went
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 103
Зарегистрирован: 01.09.2004 (Ср) 17:25
Откуда: Rostov-on-Don

Опять DAO...теперь в картинках

Сообщение Went » 27.02.2010 (Сб) 11:07

Возникла проблема с совместимостью вложений в базе данных. Попытка загнать в базу картинку выдает ошибку преобразования типов.
DAO 3.6
код примерно такой:
Код: Выделить всё
d2.Execute "CREATE TABLE tt(RecD LONGBINARY)"
Set d3 = d2.OpenRecordset("SELECT * FROM tt")
d3.AddNew
d3.Fields(0) = Picture1.Picture
d3.Update

При открытии созданной базы Access видит поле RecD как объект OLE, то есть предположительно тип поля указан верно. Скажите, пожалуйста, что нужно сделать с картинкой в PictureBox, чтобы она нормально записалась в БД? Ну и сразу, как ее потом обратно в PictureBox?
Не все ОПЕРАТОРЫ одинаково хороши

SergT
Бывалый
Бывалый
Аватара пользователя
 
Сообщения: 237
Зарегистрирован: 22.06.2005 (Ср) 21:50
Откуда: Москва

Re: Опять DAO...теперь в картинках

Сообщение SergT » 27.02.2010 (Сб) 19:42

Первое, что попалось на форуме, может быть поможет тебе разобраться:
viewtopic.php?f=5&t=15462

А вообще-то, задумайся, что и куда ты пытаешься сохранить.

http://am.rusimport.ru/MsAccess/topic.aspx?ID=271
http://www.sql.ru/forum/actualthread.aspx?tid=623470

http://otvet.mail.ru/question/34013347/
Л. Толстой, «зачем обдумывать обдуманное, бери готовое и иди дальше, в этом сила человечества»
"Всё в наших руках, поэтому их нельзя опускать" (Коко Шанель)

Went
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 103
Зарегистрирован: 01.09.2004 (Ср) 17:25
Откуда: Rostov-on-Don

Re: Опять DAO...теперь в картинках

Сообщение Went » 28.02.2010 (Вс) 14:22

viewtopic.php?f=5&t=15462

Тут идет речь о связанном через DataControl с базой объекте с картинкой. Да, там это все автоматизировано, но в моем случае автоматизация будет мешать.

Эти повеселее. Хотя и не применимо. У меня картинка первоначально подгружается в PictureBox, а уж потом, с одобрения пользователя пишется в БД.
Намек на то, что PictureBox при загрузке все равно дает конверт в bmp и что в базе картинки хранятся в том же виде мне и так ясен. Я потому и пытался загнать напрямую. Надо раздобыть что-то вроде конвертера из iPictureDisp в бинарку. Или, как вариант, писать побайтно в базу строку, состоящую из символов по принципу 1-3 символа (в зависимости от битности картинки) на точку. А символы цеплять через "Picture.Point". Правда, этот метод точночть даст маленькую, картинки потом восстанавливаться будут не очень симпатично, с пробелами. Но зато место сэкономить можно. Но будет строгое правило по поводу размера и "разрешения" контрола Picture, точнее при синхронизации их (а они различны).
По идее, в iPictureDisp или StdPicture должно быть что-то вроде свойства, содержащего "бинарный набор" самой картинки или ссылки на этот набор где-то в памяти. Что-то, что как раз и можно будет загнать в базу как бинарный поток. Ну и тем же путем его восстановить потом обратно. Не подскажете?
Не все ОПЕРАТОРЫ одинаково хороши

Went
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 103
Зарегистрирован: 01.09.2004 (Ср) 17:25
Откуда: Rostov-on-Don

Re: Опять DAO...теперь в картинках

Сообщение Went » 28.02.2010 (Вс) 15:36

Кто ищет, тот найдет. Хотя и должно было дойти до тонких граней мозга, что спрашивать у поисковиков. Тут меня статьи, подсказанные SergT натолкнули.
По существу - вот:
http://www.sql.ru/forum/actualthread.as ... &tid=29463
а вот файлег для работы последних процедур:
http://www.sql.ru/forum/actualfile.aspx?id=2436575

И пусть кому-то будет проще, чем мне ;)
Не все ОПЕРАТОРЫ одинаково хороши

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Re: Опять DAO...теперь в картинках

Сообщение alibek » 01.03.2010 (Пн) 10:48

Went писал(а):Эти повеселее. Хотя и не применимо. У меня картинка первоначально подгружается в PictureBox, а уж потом, с одобрения пользователя пишется в БД.
Намек на то, что PictureBox при загрузке все равно дает конверт в bmp и что в базе картинки хранятся в том же виде мне и так ясен. Я потому и пытался загнать напрямую. Надо раздобыть что-то вроде конвертера из iPictureDisp в бинарку. Или, как вариант, писать побайтно в базу строку, состоящую из символов по принципу 1-3 символа (в зависимости от битности картинки) на точку. А символы цеплять через "Picture.Point". Правда, этот метод точночть даст маленькую, картинки потом восстанавливаться будут не очень симпатично, с пробелами. Но зато место сэкономить можно. Но будет строгое правило по поводу размера и "разрешения" контрола Picture, точнее при синхронизации их (а они различны).

Тогда забудь про OLE. Тип данных должен быть blob (или как там в Access он называется).
А загружать/выгружать картинку в байтовый массив можно, если поискать на форуме по ключевому слову stdpicture. Первая же ссылка: viewtopic.php?p=10521#p10521
Lasciate ogni speranza, voi ch'entrate.


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: AhrefsBot, Yandex-бот и гости: 19

    TopList