Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/19: Рейтинг темы: голосов - 19, средняя оценка - 4.95
7 / 7 / 0
Регистрация: 22.10.2009
Сообщений: 51

ADO+Access картинки и загрузка по пути к файлу

06.07.2012, 15:07. Показов 3794. Ответов 16
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть готовая база, в которой картинка (одна) сохраняется прямо в ОЛЕ поле Аксеса. Но это не вариант, т.к. 4 картинки и вес базы - 16Мб. Как сделать загрузку и сохранение картинки в базу по пути(папка для картинок находится в корне программы) и в то же время, как приклеить к одной записи несколько картинок?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.07.2012, 15:07
Ответы с готовыми решениями:

Qt загрузка картинки по полному пути
Здравствуйте уважаемые форумчане возникла ни откуда такая проблема, гружу картинку по полному пути. block1 =...

Знак равенства в пути к файлу БД Access вызывает ошибку
Здравствуйте. Есть проблема при подключении к БД Access через ODBC, если в пути к БД встречается знак равенства. Вот процедура...

Загрузка изображения через форму и запись пути к этому файлу в базу данных
Всем добрый день. Вопрос такой: как через форму загрузить изображение в папку на локальный сервер, а затем записать путь к этому файлу в...

16
1 / 1 / 0
Регистрация: 06.07.2012
Сообщений: 6
06.07.2012, 15:16
Цитата Сообщение от Life_Master Посмотреть сообщение
Есть готовая база, в которой картинка (одна) сохраняется прямо в ОЛЕ поле Аксеса. Но это не вариант, т.к. 4 картинки и вес базы - 16Мб. Как сделать загрузку и сохранение картинки в базу по пути(папка для картинок находится в корне программы) и в то же время, как приклеить к одной записи несколько картинок?
я делал так

Delphi
1
2
imgpath:=ExtractFilePath(Application.ExeName)+'\img\'+ DBGrid1.DataSource.DataSet.FieldByName('ID').AsString+'.jpg';
Image1.Picture.LoadFromFile(imgpath);
Id уникальный
картинки берет из папки img , что рядом с исполняемым файлом.
1
7 / 7 / 0
Регистрация: 22.10.2009
Сообщений: 51
06.07.2012, 15:25  [ТС]
Работает)))

Остался второй вопрос.
0
1 / 1 / 0
Регистрация: 06.07.2012
Сообщений: 6
06.07.2012, 15:31
несколько картинок?
Ну добавь счетчик в имя файла. Типа ID_00.jpg
0
 Аватар для Артём121
66 / 65 / 13
Регистрация: 15.11.2010
Сообщений: 396
Записей в блоге: 1
06.07.2012, 15:39
Если хочешь делать несколько картинок , то нужно делать отдельную таблицу. Например, Таблица1 : Код_сотрудника, ФИО ; Таблица2 : Код_картинки, Путь, Код_сотрудника
0
7 / 7 / 0
Регистрация: 22.10.2009
Сообщений: 51
06.07.2012, 15:42  [ТС]
я не совсем понимаю, как обработать счетчик?
может проще сделать связанную таблицу?
0
1 / 1 / 0
Регистрация: 06.07.2012
Сообщений: 6
06.07.2012, 15:49
новую таблицу, конечно лучше.
как Артём написал, только в таблице2 лучше вместо "Путь" использовать "имяфайла", ибо жесткие пути не есть хорошо.
0
7 / 7 / 0
Регистрация: 22.10.2009
Сообщений: 51
07.07.2012, 22:44  [ТС]
пробывал, но не получилось.

вот структура таблицы:
-счетчик
-название
-описание
-картинка

счетчик можно же использовать как уник к записи?

вторая таблица - картинка и уник, сделал связь между униками из двух таблиц, но в программе что сделать - не догнал.
0
 Аватар для Артём121
66 / 65 / 13
Регистрация: 15.11.2010
Сообщений: 396
Записей в блоге: 1
07.07.2012, 22:58
Вот что должно быть взято за основу. Как видишь, отношение между таблицами Клиенты и Фото один-ко-многим, т е одной записи будет соответствовать множество картинок
Миниатюры
ADO+Access картинки и загрузка по пути к файлу  
1
7 / 7 / 0
Регистрация: 22.10.2009
Сообщений: 51
07.07.2012, 23:38  [ТС]
будем пробывать)
0
7 / 7 / 0
Регистрация: 22.10.2009
Сообщений: 51
09.07.2012, 15:10  [ТС]
спрошу здесь, чтобы не создавать новую тему.

На форме лежит чекбокс, хочется чтобы при Checkbox.Enabled в dbgride отображались только те записи, в которых определенное поле пустое. Например, 3 поля - ИД, Автор, Описание. Поле описание
пустое, и при чекбоксе - оно должно отобразиться в дбгриде, иначе - все записи отображаются.

Пробывал такой код, не пашет через квери:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
procedure TForm1.CheckBox1Click(Sender: TObject);
begin
with DBGrid1 do
begin
if (CheckBox1.Checked) then
begin
  DataModule1.ADOQuery1.Active:=false;
  DataModule1.ADOQuery1.Close;
  DataModule1.ADOQuery1.SQL.Clear;
  DataModule1.ADOQuery1.SQL.Add('select * from book where opisanie is null');
  DataModule1.ADOQuery1.Open;
  DataModule1.ADOQuery1.Active:=true;
end
else
begin
  DataModule1.ADOQuery1.Active:=false;
  DataModule1.ADOquery1.Close;
  DataModule1.ADOQuery1.SQL.Clear;
  DataModule1.ADOQuery1.SQL.Add('select * from book');
  DataModule1.ADOQuery1.Open;
  DataModule1.ADOQuery1.Active:=true;
end;
end;
end;
0
 Аватар для Артём121
66 / 65 / 13
Регистрация: 15.11.2010
Сообщений: 396
Записей в блоге: 1
09.07.2012, 18:17
Эта строчка кода
Delphi
1
DataModule1.ADOQuery1.Open;
эквивалентна
Delphi
1
DataModule1.ADOQuery1.Active:=true;
Т.е. эти строки кода не могут быть вместе, т к выполняют одну и ту же операцию

Добавлено через 40 секунд
Тоже самое с
Delphi
1
2
DataModule1.ADOQuery1.Active:=false;
  DataModule1.ADOQuery1.Close;
Добавлено через 2 минуты
Код по логике правильный. Может покажешь скрины результатов при выборе чекбокса.
0
 Аватар для HyperZen
498 / 251 / 56
Регистрация: 16.06.2011
Сообщений: 904
09.07.2012, 18:35
А зачем здесь вот это?
Цитата Сообщение от Life_Master Посмотреть сообщение
Delphi
1
with DBGrid1 do
Добавлено через 1 минуту
Предлагаю сократить код, до:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
begin
if (CheckBox1.Checked) then
  begin
    DataModule1.ADOQuery1.SQL.Text := 'select * from book where opisanie is null';
    DataModule1.ADOQuery1.Open;
  end
    else
  begin
    DataModule1.ADOQuery1.SQL.Text := 'select * from book';
    DataModule1.ADOQuery1.Open;
  end;
end;
0
7 / 7 / 0
Регистрация: 22.10.2009
Сообщений: 51
09.07.2012, 22:03  [ТС]
with DBGrid1 do - это лишнее, забыл убрать.

А скрины не нужны - реакции вообще нет никакой.
0
 Аватар для HyperZen
498 / 251 / 56
Регистрация: 16.06.2011
Сообщений: 904
10.07.2012, 05:02
Раз нет реакции, выкладывайте проект...
0
 Аватар для HyperZen
498 / 251 / 56
Регистрация: 16.06.2011
Сообщений: 904
10.07.2012, 05:13
Вот демопроект (D2010)...
Вложения
Тип файла: rar TestPr.rar (15.1 Кб, 45 просмотров)
0
7 / 7 / 0
Регистрация: 22.10.2009
Сообщений: 51
15.07.2012, 03:08  [ТС]
у меня delphi 7, 2010 не открывается.

выкладываю весь проект, там еще косяк есть с поиском по полям, тоже по чекбоксам...
Вложения
Тип файла: rar Программа.rar (351.1 Кб, 42 просмотров)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.07.2012, 03:08
Помогаю со студенческими работами здесь

Загрузка картинки в image по относительному пути
Есть image в который нужно загрузить картинку из папки images,файл у меня называется так же как и название моего рецепта(у меня кулинарная...

загрузка картинки на сервер и запись пути к ней в бд
Взываю к чужим мозгам, т.к. своих по части php пока ече мало! Есть таблица afiha в ней вся инфа по афишам и картинки к каждой из...

Выведение картинки с сервера php в результатах поиска на основании пути к файлу, содержащемуся в базе данных MySQL
Здравствуйте. Я новичок в PHP и MySQL (относительно) и ещё много чего не знаю. Я пишу себе сайт, который уже имеет базу данных MySQL,...

Загрузка progressBar во время загрузки картинки в pictureBox из пути
Здравствуйте. :read: Можно сделать так, чтобы progressBar появлялся на экране и не зависал, после того, как мы нажали на кнопку, у...

Обработка картинки функцией getimagesize, задание пути к файлу для её работы (работы функции)
Здравствуйте. Я создаю сайт. Мне нужно сделать так, чтобы пользователи могли загружать туда картинки любого размера (Ширины и Высоты),...


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

Или воспользуйтесь поиском по форуму:
17
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru