Javascript-форум (https://javascript.ru/forum/)
-   Серверные языки и технологии (https://javascript.ru/forum/server/)
-   -   Определение последней итерации цикла. (https://javascript.ru/forum/server/31984-opredelenie-poslednejj-iteracii-cikla.html)

Allan Stark 28.09.2012 10:52

Определение последней итерации цикла.
 
Здравствуйте.
Имеется сценарий php, он делает ряд запросов к БД Firebird, на основании которых формирует довольно сложный (большое кол-во вложенности, разная структура "чилдренов") json вывод для скрипта на стороне клиента.

Вывод ведется на основании echo() из выборки по ibase_fetch_row(), т.е. сразу в поток, без предварительного формирования массивов и json_encode().

Вопрос.
Как исхитриться и определить конец последней итерации в каждом из циклов вида while ($row = ibase_fetch_row($db_fb_query)) {...} ?
Управляющие конструкции и условие по сравнению типа end() или next() по примеру http://dycore.blogspot.com/2010/03/foreach-php.html тут не катят, т.к. работаем не с массивом.

Определение последней итерации необходимо, чтобы выяснить, ставить ли в конце после некоторых "}" символ запятой или нет.

Создавать многомерные вложенные массивы и строить деревья будет сложновато, т.к. сценарий будет в будущем неоднократно модифицироваться. Выводить сперва в строку, а затем тримить ее справа на "," и затем отдавать в эху - тоже не совсем хорошо, строки могут быть очень длинные, потенциально можно упереться в прекомпиленное значение длины строкового типа 65539 на каком-нибудь хостинге...

Skipp 28.09.2012 13:22

После цикла делайте rtrim(",") и всё:)

Allan Stark 28.09.2012 13:43

Цитата:

Сообщение от Skipp (Сообщение 207005)
После цикла делайте rtrim(",") и всё:)

Не получится, rtrim требует в качестве обязательного параметра входную строку, что мы ему передавать будем, если в сценарии вывод в поток на отдачу сразу через echo идет, без промежуточного сохранения/сбора строки для вывода.

Skipp 28.09.2012 13:48

эмм, а почему не собирать в одну строку? В чём проблема? Просто вы так как минимум делаете лишние телодвижения, так как есть разница у одного echo и тысячи echo.

Другое предложение: создайте переменную которая будет увеличиваться с каждым проходом цикла и сравнивайте с общим количеством полученных записей.

Allan Stark 28.09.2012 13:53

В строку собрать нельзя, т.к. прекомпиленный php по дефолту имеет (если память не изменяет) ограничение для строкового типа в 65539.
100% можно будет в будущем нарваться на хостинг с таким ограничением...

Allan Stark 28.09.2012 13:54

Общее кол-во записей в ibase к сожалению получить невозможно без предварительного прогона "впустую" запроса (и подсчета кол-ва выданных строк в цикле), аналога того же mysql_num_rows() в php для него просто нет...

Skipp 28.09.2012 14:17

Если я не ошибаюсь, то в php нету ограничения на длину строки, кроме как объём оперативки, но есть ограничение буфера вывода.
И вот есть такое решение для echo

Allan Stark 28.09.2012 14:22

Хм, возможно вы и правы.
Просто когда-то натыкался на явное ограничение в работе строковых функций с длинными строками...

Skipp 28.09.2012 14:27

Allan Stark,
Вот допустим тут написано тоже самое:)

Allan Stark 28.09.2012 14:28

И здесь тоже:
http://php.ua/blog/2012-01-16/preg_m...E%D0%BA%D0%B8/

:)


Часовой пояс GMT +3, время: 11:52.