Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.96/25: Рейтинг темы: голосов - 25, средняя оценка - 4.96
 Аватар для ExeiLj
13 / 13 / 3
Регистрация: 02.08.2012
Сообщений: 128

Как работать с ADO, как с массивом?

15.03.2013, 17:23. Показов 4780. Ответов 27
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите пожалуйста, есть ли способ работать с ADOQuery/ADOTable/DataSource etc, как с массивом?

Т.е. я подключил БД через АДО, и теперь работаю так:
C++
1
2
DataModule->ADOQuery->RecNo=11;
String some_var = DataModule->ADOQuery->Fields->Fields[22]->AsString;
Но есть ли способ работать как с массивом? Например:
C++
1
String some_var = some_AdoQuery->Array[11][22];
Добавлено через 6 минут
т.е. надо постоянно выполнять перемещение по строкам, можно ли избежать этого лишнего действия?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.03.2013, 17:23
Ответы с готовыми решениями:

Работать с массивом, как с набором различных по типу элементов
Посидел, пытался как-то перевести BYTE в wchar_t. Но так и не смог.. Не знаю, как даже сделать перевод. Помогите пожалуйста. ...

Как создать временную таблицу и как с ней работать?
Итак приступим у меня билдер 6, бд ацесс 2003. Для оптимизации многопользовательской работы по сети я задумал создавать временную таблицу...

Как работать с изображением как с массивом пикселей
Загрузить изображение в память\буфер\куда нибудь, считать значение цвета по координатам и что нибудь на нём отрисовать.

27
1569 / 505 / 48
Регистрация: 04.04.2009
Сообщений: 1,891
19.03.2013, 11:11
Студворк — интернет-сервис помощи студентам
ExeiLj,
Цитата Сообщение от ExeiLj Посмотреть сообщение
В каком месте это проще
Мы с Вами с чего начали? Правильно, начали за здравие с сравнения "простоты" работы с обычным массивом данных и со сформированным НД. Вот я Вам и не стал перечить по поводу заявления:
Цитата Сообщение от ExeiLj Посмотреть сообщение
с массивом работать проще.
А уж насчет памяти - извиняйте. Или Вам и "простоту" подавайте и оптимизацию (относительно ресурсопотребляемости)?



Касательно общего вопроса:
Цитата Сообщение от ExeiLj Посмотреть сообщение
Подскажите пожалуйста, есть ли способ работать с ADOQuery/ADOTable/DataSource etc, как с массивом?
С учетом введения "работы с массивом":
Цитата Сообщение от ExeiLj Посмотреть сообщение
C++
1
for (int i=0; i<count; i++) { if arr[i-1][1] == "" && arr[i+1][1] == "" { ... } }
Отвечаю: никак.
0
 Аватар для ExeiLj
13 / 13 / 3
Регистрация: 02.08.2012
Сообщений: 128
19.03.2013, 12:32  [ТС]
Цитата Сообщение от The_Immortal Посмотреть сообщение
Отвечаю: никак.
Ну собственно это я и хотел услышать, чтобы убедиться, что я не кодирую через дебри))

Добавлено через 3 минуты
А этот ADO оказался довольно глючной штукой, виснет на последней строчке, если поставить условие:
C++
1
2
TADOQuery *xlsA = DataModule2->ADOQuery1;
for (xlsA->RecNo=1; xlsA->RecNo<=xlsA->RecordCount; xlsA->RecNo++)
а вот если равно убрать из условия, то он не виснет, но и последнюю строчку не обрабатывает...
C++
1
for (xlsA->RecNo=1; xlsA->RecNo<xlsA->RecordCount; xlsA->RecNo++)
0
1569 / 505 / 48
Регистрация: 04.04.2009
Сообщений: 1,891
19.03.2013, 13:08
ExeiLj,

Цитата Сообщение от ExeiLj Посмотреть сообщение
я не кодирую через дебри))
Я бы не был так уверен


Цитата Сообщение от ExeiLj Посмотреть сообщение
C++
1
TADOQuery *xlsA = DataModule2->ADOQuery1; for (xlsA->RecNo=1; xlsA->RecNo<=xlsA->RecordCount; xlsA->RecNo++)
- что это вообще такое?

Выше же был пример с использованием свойства Eof и метода Next.

Да и плюс имеет смысл прислушиваться к Ветеранам:

Цитата Сообщение от Lord_Voodoo Посмотреть сообщение
Если мне память не изменяет, то Recno корректно использовалось только для Парадокса, а потом осталось в TDataSet для совместимости, ну и как пережиток уже далекого прошлого...
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
19.03.2013, 13:45
ExeiLj, да уж... штаны одеть можно через голову, но вот вопрос - а надо ли?
2
 Аватар для ExeiLj
13 / 13 / 3
Регистрация: 02.08.2012
Сообщений: 128
19.03.2013, 19:07  [ТС]
Цитата Сообщение от The_Immortal Посмотреть сообщение
- что это вообще такое?
Цикл for проходящий по всем строкам таблицы.

Цитата Сообщение от The_Immortal Посмотреть сообщение
Выше же был пример с использованием свойства Eof и метода Next.
Да и плюс имеет смысл прислушиваться к Ветеранам:
Мне нужно менять позицию (RecNo) постоянно (в теле цикла в зависимости от условий), поэтому ее и использовал.
И вообще, я это накодил до создания данной темы, и не знал, что RecNo лучше не использовать.

Кстати без RecNo номер строки не узнать...

Цитата Сообщение от Lord_Voodoo Посмотреть сообщение
ExeiLj, да уж... штаны одеть можно через голову, но вот вопрос - а надо ли?
Я же не просто так создал эту тему, а чтобы узнать "через что я натягиваю штаны" и как это исправить...
0
1569 / 505 / 48
Регистрация: 04.04.2009
Сообщений: 1,891
19.03.2013, 22:10
ExeiLj,
Цитата Сообщение от ExeiLj Посмотреть сообщение
Цикл for проходящий по всем строкам таблицы.
поясните, пожалуйста, чем Вас цикл while не устраивает:

C++
1
2
3
4
5
6
7
DataModule2->ADOQuery1->First();
 
while(!DataModule2->ADOQuery1->Eof())
{
  ...
  DataModule2->ADOQuery1->Next();
}
Или этот цикл не позволяет
Цитата Сообщение от ExeiLj Посмотреть сообщение
менять позицию (RecNo) постоянно (в теле цикла в зависимости от условий)
?
0
480 / 393 / 113
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
20.03.2013, 08:38
Цитата Сообщение от ExeiLj Посмотреть сообщение
for (xlsA->RecNo=1; xlsA->RecNo<=xlsA->RecordCount; xlsA->RecNo++)
если через for то лучше так (на сколько я помню, сам так не делаю)
C++
1
for (xlsA->First(); !xlsA->Eof; xlsA->Next())
Цитата Сообщение от ExeiLj Посмотреть сообщение
Мне нужно менять позицию (RecNo) постоянно (в теле цикла в зависимости от условий), поэтому ее и использовал.
а для "разбора полёта над дебрями" лучше привести код полностью
0
 Аватар для ExeiLj
13 / 13 / 3
Регистрация: 02.08.2012
Сообщений: 128
20.03.2013, 12:12  [ТС]
Цитата Сообщение от The_Immortal Посмотреть сообщение
ExeiLj,

поясните, пожалуйста, чем Вас цикл while не устраивает:
Или этот цикл не позволяет
?
Устраивает всем, говорю же, что не знал что есть разница


Цитата Сообщение от Bit_Man Посмотреть сообщение
а для "разбора полёта над дебрями" лучше привести код полностью
Я его уже полностью переписал. Все запихал в вектор и отключил глючное АДО вовсе)))
Работает гораздо быстрее)))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.03.2013, 12:12

Как работать с ADO.NET?
Visual Studio 2013 Premium, в вкладке C# нет раздела Database / Data. Не могу найти шаблоны с ADO.NET. Пробовал установить Entity Framework...

Как работать с ADO Stream?
Как работать с ADO.STREAM? Надо в рекордсет записать jpeg картинку!Запостите пример, плиз.

Как научиться работать с ADO.NET
Чувствую некоторую неловкость , когда задаю вопросы на форуме - возможно из-за низкого уровня подготовки. Думаю многие вопросы можно было...

Как работать с двумерным массивом?
Есть такой вот массив: int ary = { { 1, 2, 3, 4, 5 }, { 2, 4, 6, 8, 10 }, { 3, 6, 9, 12, 15 } Здесь 3 строки и 5...

Как правильно работать с массивом?
$N = 1; @KonstruktorRj = (); for($U=0;$U&lt;=58;$U++) { @KonstruktorRj = ('|! Туда...


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

Или воспользуйтесь поиском по форуму:
28
Ответ Создать тему
Новые блоги и статьи
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи. Через несколько переработок от PHP кода к C89 (надеюсь, 89). Но довольно запутанно получилось. Код для Linux. Но если убрать time и то, что с ним. . .
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы Всем привет! Хочу поделиться свежим (и довольно. . .
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения: - добавлена многоязычность - добавлено снятие скриншотов - добавлено поддержание бафов хождения по воде (для жреца, дк и шамана) - и так, по. . .
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу))) Критические ошибки, мешающие компиляции и. . .
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата) Этот документ предназначен для того, чтобы новый чат Claude мог продолжить работу без необходимости заново разбираться в. . .
сукцессия 15 неявная схема
anaschu 29.06.2026
Алиса Калибровка параметров симбиотической модели: технический обзор Содержание: Введение Постановка проблемы Технические аспекты реализации Процесс внедрения изменений
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru