Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
Подключаюсь к Oracle из C++. Как узнать количество строк в ResultSet? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 10:00 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
На самом деле, во всех СУБД и всех клиентах единственный способ узнать количество строк в наборе данных -- это профетчить (выбрать на клиента) все строки и посчитать их количество. Разные API типа ODBC и OLEDB имеют для этого специальные функции, которые внутри, на самом деле, делают ровно то же самое -- считают профетченные строки. И, чтобы предотвратить возможное возмущение, добавлю, что до выборки последней записи набора данных о количестве строк в нём не знает даже сам сервер СУБД -- в момент начала работы с набором данных на клиенте (или в сервере -- не важно) набор только сформирован как запрос и подготовлен к выборке из него, но записей там ещё нет, они будут формироваться по мере надобности для использующего этот набор данных. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 11:24 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
Получается это неправильный стиль программирования, сначала узнать количество строк, а потом взять данные в цикле? Код: plaintext 1. 2. 3. 4. 5. 6. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 12:14 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
sitev_ruПолучается это неправильный стиль программирования, сначала узнать количество строк, а потом взять данные в цикле? Да, совершенно неправильный. Posted via ActualForum NNTP Server 1.5 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 12:30 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
sitev_ruПолучается это неправильный стиль программирования, сначала узнать количество строк, а потом взять данные в цикле? 1. Ты вынужден дождаться пока придет весь результат запроса на клиента. Хотя можно было начитать обрабатывать по мере поступления. 2. Результат сначала должен быть как-то закэширован чтобы потом ты его из кэша вычитывал, т.е. лишний расход памяти. И все это только ради того чтобы заранее узнать сколько записей, при том что для решения основной задачи это не надо, надо только чтобы цикл организовать. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 12:34 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
sitev_ruПолучается это неправильный стиль программирования, сначала узнать количество строк, а потом взять данные в цикле? Код: plaintext 1. 2. 3. 4. 5. 6. Касательно работы с СУБД -- да. Антипаттерн. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 12:35 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
sitev_ruПолучается это неправильный стиль программирования, сначала узнать количество строк, а потом взять данные в цикле? Не в стиле дело. Ты делаешь в 2 транзакции. А значит что ты узнал одно количество строк. Потом прошёл ненулевой интервал времени. За это время в БД что-то поменялось и ты извлекаешь данные как будто уже из "другой БД". И количество там будет другое. Это называется несогласованность. Решений твоей проблемы много. Ответы вобщем зависят от возможностей самой DBMS. Например зафикисровать снапшот и работать с ним. Или использовать выборку 1 раз и для подсчёта и для публикации. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 13:07 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
maytonsitev_ruПолучается это неправильный стиль программирования, сначала узнать количество строк, а потом взять данные в цикле? Не в стиле дело. Ты делаешь в 2 транзакции. А значит что ты узнал одно количество строк. Потом прошёл ненулевой интервал времени. За это время в БД что-то поменялось и ты извлекаешь данные как будто уже из "другой БД". И количество там будет другое. Это называется несогласованность. Ну про это ж разговора вообще не было... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 14:21 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
Обычно использую такую конструкцию для вывода информации на экран. Изначально предполагается, что будет немного информации и поэтому такой цикл прокатывал. Но теперь получается, что нужно переходить на новую схему... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 15:28 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
А зачем тебе количество знать? Цикл можно по другому переписать. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 15:45 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
sitev_ruОбычно использую такую конструкцию для вывода информации на экран. Смысл? Показать пользователю что процесс идет? Если так, то им пофиг сколько до конца осталось (за исключением каких-то очень долгих расчетов). Достаточно показать сколько обработано. Показывай "Обработано ХХХ записей ..." и обновляй каждые полсекунды-секунду (чтобы вывод оповещения не затормаживал сам расчет). ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 16:22 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
Для сложного (5 и более JOINS) запроса очень сложно нарисовать progress-bar. Особенно в фазе execute. Тут конечно всё от dbms зависит но мои попытки сделать оценку оставшегося времени или нарисовать % шкалу ничем не закончились. Возможно это фундаментальный недостаток реляционной алгебры. Для сложных соединений отклик - непрогнозируем. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 16:27 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
maytonДля сложного (5 и более JOINS) запроса очень сложно нарисовать progress-bar. Не сложно -- НЕВОЗМОЖНО! ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 19:19 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
sitev_ruПодключаюсь к Oracle из C++. Как узнать количество строк в ResultSet?если это оракл, то в запрос можно добавить оконную функцию, которая и посчитает "количество строк в ResultSet" Код: plsql 1. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.09.2015, 23:46 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
Relic Huntersitev_ruПодключаюсь к Oracle из C++. Как узнать количество строк в ResultSet?если это оракл, то в запрос можно добавить оконную функцию, которая и посчитает "количество строк в ResultSet" Код: plsql 1. А что тут общего с количеством строк? И вообще, оконные функции это группировка. А о ней никто не заикался. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 00:44 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
White Owl, Колонка "CNT" это и есть количество строк :) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 02:18 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
Это такой древний туннгуский способ получить в одном запросе сами данные и их количество. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 02:20 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
Relic HunterWhite Owl, Колонка "CNT" это и есть количество строк :)Это не количество строк, а количество записей имеющих одинаковый id. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 02:45 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
mayton, Можно, но я так привык писать на MySQL... Вот отрывок исходника https://github.com/sitev/cjCms/blob/master/src/siteManager.cpp: Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. Теперь мои наработки должны заработать под Oracle... Хотя уже решил всё переписать с помощью next() ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 08:06 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
Вывожу новости... Последняя новость должна выводиться чуть по-другому... Как определить, что она последняя? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 09:41 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
sitev_ruВывожу новости... Последняя новость должна выводиться чуть по-другому... Как определить, что она последняя? Выводить в опозданием на один шаг. Т.е. прочитал, запомнил, перешел на следующую, обрабатывай запомненное. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 09:44 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
Dima T, я конечно думал об этом... но не думал, что придётся так и реализовать)) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 10:09 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
sitev_ruDima T, я конечно думал об этом... но не думал, что придётся так и реализовать)) План Б: отсортировать в обратном порядке, тогда последний станет первым :) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 10:11 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
Dima T, Чёрт! Ты, гений! В это чё-то есть... хотя может быть это только усложнит программу, надо подумать) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 10:21 |
|
||
|
Oracle ResultSet C++ узнать количество строк
|
|||
|---|---|---|---|
|
#18+
sitev_ruМожно, но я так привык писать на MySQL... Вот отрывок исходника https://github.com/sitev/cjCms/blob/master/src/siteManager.cpp: Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. Для MySQL это тоже неправильный подход. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 02.09.2015, 10:32 |
|
||
|
|

start [/forum/topic.php?fid=57&msg=39041174&tid=2018862]: |
0ms |
get settings: |
9ms |
get forum list: |
12ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
51ms |
get topic data: |
9ms |
get forum data: |
2ms |
get page messages: |
54ms |
get tp. blocked users: |
1ms |
| others: | 12ms |
| total: | 158ms |

| 0 / 0 |
