Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.61/18: Рейтинг темы: голосов - 18, средняя оценка - 4.61
1 / 1 / 1
Регистрация: 27.11.2014
Сообщений: 115

Запись в массив ячеек из DBGrid

07.05.2015, 11:44. Показов 3405. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый День!
Помогите решить очередную задачу...

Есть таблица из которой нужно считать все данные из каждой ячейки в массив, подключение - ADOConnection. ADOTable, DataSource. Так как DBGrid не хранит информацию, а только отображает, и нельзя обратиться к каждой ячейке так как в StringGrid то как прочитать данные со всей таблицы?
Нашел пример, что вот так можно считать в переменные из ячеек в выделенной строке

Delphi
1
2
a := DBGrid.DataSource.DataSet.FieldByName('Имя').AsString;
b := DBGrid.DataSource.DataSet.FieldByName('Фамилия').AsString;
Но если колонок в таблице например десять и для каждой писать такую строку то ведь код очень громоздкий получится

Как это в цикле сделать и не для выделенной строки?
И как прочитать с остальных строк если их в таблице может быть пять или семь?

Добавлено через 1 час 6 минут
Вот нашел еще пример - копирование содержимого в StringGrid
Может на основании этого примера можно записать и массив?
и здесь используется ADOQuery а у меня ADOTable
Как это сделать, помогите пожалуйста, буду очень благодарен

Delphi
1
2
3
4
5
6
7
8
9
10
11
StringGrid1.RowCount:=ADOQuery1.RecordCount;
StringGrid1.ColCount:=ADOQuery1.FieldCount;
ADOQuery1.First;
for i:=0 to ADOQuery1.RecordCount-1 do
  begin
    for j:=0 to ADOQuery1.FieldCount-1 do
      begin
        StringGrid1.Cells[j,i]:=ADOQuery1.Fields.Fields[j].AsString;
      end;
    ADOQuery1.Next;
  end;
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.05.2015, 11:44
Ответы с готовыми решениями:

Закрашивание ячеек DBGrid
Вечер добрый всем! Подскажите, пожалуйста, как закрасить ячейки в DBGrid по определенному значению? Есть код: procedure...

Активность ячеек в DBGrid
Здравствуйте, подскажите пожалуйста, можно ли в Делфе в dbGrid сделать активные ячейки, т.е (дпустим)при нажатии на пр.кнопку мыши в...

Форматирование ячеек в DBGrid
Возможно не понятно объясню, если что спросите:) проблем вот в чем: как сделать так чтобы при написании в etid Фирма "(название...

2
1263 / 706 / 62
Регистрация: 21.12.2009
Сообщений: 2,256
07.05.2015, 11:55
У DBGrid есть свойство Columns. Это коллекция колонок грида. Обратиться к конкретной колонке грида можно так
DNGrid.Colums[i]
Здесь i - целая переменная, порядковый номер колонки.
Копай в этом направлении. Там есть все, что тебе надо.
0
1 / 1 / 1
Регистрация: 27.11.2014
Сообщений: 115
07.05.2015, 12:02  [ТС]
SAMZ, Спасибо за ответ! Но к конкретной колонке я могу обратиться так и записать в переменную из ячейки колонки "Имя" выделенной строки

Delphi
1
a := DBGrid.DataSource.DataSet.FieldByName('Имя').AsString;
А к строкам то как и не выделенным?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.05.2015, 12:02
Помогаю со студенческими работами здесь

Объединение ячеек в DBGrid
У меня есть 2 dbgrd, на разных формах. При нажатии на кнопку button значения из dbgrd2(приходная накладная) переносятся на на другой...

Выделение цветом ячеек DBGrid
У меня есть таблица отображается в dbgrid, нужно чтобы выбраная строка вся выделялась цветом(как на скриншоте(там я в паинте сделал). И...

Сложение определенных ячеек Dbgrid
Привет всем! Создаю базу данных в Delphi 7 (paradox). В программе есть несколько форм, на которых расположенны базы данных DBGrid. У каждой...

Как ограничить выбор ячеек в DBGrid
Имеется форма,на ней DBGrid подключен к таблице access. В процедуре прописал : procedure TForm_general.DBGrid1DblClick(Sender:...

Поиск и закраска одинаковых ячеек в DBGrid
Привет форумчане! Есть MySQL. В ней общая сводная таблица. Информация выводится в три DBGrid в зависимости от запроса. Возникла...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru