Один элемент викторины на страницу (программа тестирования php / mysql) Петля через массив php подсчет часов и добавление минут в php Ошибка при подключении к MySQL с использованием PHP / P.
#x430;вить javascript в php? кодировки mySQL и PHP Есть ли способ заставить FPDF / FPDI или Zend_Pdf поддерживать разбор PDF-файлов более чем на 1,4? Конструктор Imagick сбой PHP / CGI Лучший способ рассказать о 3 или более послед.
41F;латеж отсутствует Стоимость доставки … но только иногда Есть ли необходимость использовать амперсанд перед объектом? Как подключить два или несколько файлов и от.
ирования Silverstripe
ruphp.com
Все мы знаем про замечательные функции PHP такие как implode ( объединяет элементы массива в строку заданным разделителем) и explode ( разбивает строку в массив по заданному разделителю).
Но иногда разработчикам приходится оперировать строками с разделителем (денормализованными данными) или же наоборот – получить какие-либо данные объединенные через разделитель в базе данных. Как оказалось сделать это в MySQL не так просто.После небольшого копания в документации обнаружилось, что для объединения записей в строку можно воспользоваться функций GROUP_CONCAT. По умолчанию разделителем является запятая (символ “,”). Но его можно сменить использую параметр SEPARATOR. Приведем небольшой пример.
Пусть у нас есть таблица со списком пользователей – “users”. Из неё необходимо выбрать все ID пользователей и собрать в строку с разделителем.
CREATE TABLE `users` ( `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT, `user_name` VARCHAR(200) NULL DEFAULT NULL, PRIMARY KEY (`user_id`) ) COLLATE='utf8_general_ci' ENGINE=InnoDB ROW_FORMAT=DEFAULT
И немного заполненных данных:

Теперь выполним следующий запрос для объединения данных в строку:
SELECT GROUP_CONCAT(`id`) as string from `users`
В результате мы получим следующий набор данных:
Теперь объединим данные через символ “точка с запятой” (“;”) выполнив следующий запрос с использованием параметра SEPARATOR.
SELECT GROUP_CONCAT(`id` SEPARATOR ';') as string from `users`
В результате выборка приняла вот такое значение:
Вот так с помощью функции GROUP_CONCAT можно объединять какие-либо данные из Базы Данных через разделитель. Кроме того, в функцию можно передавать несколько полей для их конкатенации (склеивания). Что бы избежать повторяющиеся данные, можно использовать параметр DISTINCT.
У этой функции есть ограничение на объем выводимых данных. По умолчанию 1024 символа для каждого объединения – для каждой выводимой строки. Если размер склееных данных больше, то он будет урезаться. Чтобы расширить размер нужно выполнить команду (только если у Вас есть необходимые привилегии на выполение)
SET group_concat_max_len = 4096; # Нужное значение
С объединением данных на этом все. А вот что бы разобрать строку через разделитель, с этим придется повозиться дольше. Нативной поддержки этого в MySQL я не нашёл. Единственное этому решение – написание хранимой процедуры для разбора строки.
Ниже представлен дамп хранимой процедуры.
DELIMITER // CREATE PROCEDURE `explode`(IN `mylist` VARCHAR(255)) body: BEGIN IF mylist = '' THEN LEAVE body; END IF; SET @saTail = mylist; WHILE @saTail != '' DO SET @sHead = SUBSTRING_INDEX(@saTail, ',', 1); SET @saTail = SUBSTRING( @saTail, LENGTH(@sHead) + 2 ); ## Тут любой Ваш код ## Для примера добавление новых ID пользователей в таблицу users INSERT INTO users (id) VALUES (@sHead); END WHILE; END// DELIMITER ;
Процедура принимает всего 1 параметр ( для примера ). Это список значений через запятую. После этого проходит цикл по этому параметру и ищется разделитель (в нашем случае – это запятая). Каждое новое значение сохраняется в переменную @sHead и его уже можно использовать для SQL запросов.
Для вызова процедуры воспользуемся следующим кодом.
call explode('100000,1010000,1020000');
После чего новые ID пользователей появятся в таблице. Это достаточно простой пример. Чаще всего такие операции я использую для хранения денормализованных данных и последующей их нормализации (через тригеры).
Само собой поиск делается по нормализованным данным, а, если, необходимо просто вывести информацию – вывод денормализованных.
Данную процедуру Вы можете изменить и уже использовать для своих потребностей.
vexell.ru
Информация: символы, строки и данные
В «чистом» виде информация — это строка символов, речь или последовательность сигналов. В программировании фигурируют строки, массивы и объекты — это варианты искусственных строчных конструкций. Числа — это тоже строки, но цифр, а не символов.
Преобразовать строку в массив PHP позволяет множеством различных способов. Есть две специальных функции, которые делают это «самостоятельно»:
- $aArr = explode(‘x’, ‘string’);
- $aStr = implode(‘y’, $aArr).
Первая функция находит символ разделитель ‘x’ и разбивает по нему строку ‘string’. В результирующий массив попадает ровно такое количество элементов (строк), которое содержится между символами ‘x’. Символом разделителем не обязательно может выступать классические:
- запятая;
- точка;
- точка с запятой.
Разделять строку можно по подстроке или по специальному сочетанию символов.
Длина строки — strlen() на PHP, длина массива — count(). В первом случае считается количество символов, во втором случае количество элементов. Поскольку символ-разделитель не входит в элементы массива, то значение count() будет равно количеству разделителей в преобразуемой строке минус один.
При обратной трансформации PHP массивы в строку преобразуются с символом-разделителем (может быть пустым), и все данные (числа и логические выражения) сливаются в одну строку. Элементом массива может быть другой массив, но этот случай программист должен исполнить особо. Функция implode() далека от рекурсии.
В этом примере нет проблем преобразовать PHP-массивы в строку до тех пор, пока среди их элементов не окажется другого массива. При преобразовании ассоциативных элементов теряется ключевая информация. В частности, элементы «слива» и «персик» будут лишены своих ключей.
Разделители данных и ключи
Не следует считать разделителями точки, запятые, двоеточия и пр. Это частный случай разделения данных друг от друга. При трансформации строки на PHP многомерный массив не получится, а ассоциативным индексам неоткуда будет взяться.
При разборке строки по разделителю всегда получаются строки. Но это не повод останавливаться на достигнутом. Разобрав одну строку на составные элементы, можно пойти дальше.
Например, был абзац, в нем несколько предложений (разделитель «.» — точка), в предложении несколько фраз (разделители «,» — запятая, «;» — точка с запятой и «.» — точка), во фразе есть слова (разделитель » » — пробел, «,» — запятая, «;» — точка с запятой и «.» — точка).
При такой разборке на PHP многомерный массив получится легко, но алгоритм будет очень некрасивым: количество разделителей растет, а отсутствие связи между соседними абзацами гарантированно обеспечит дублирование предложений, фраз и слов.
Разбирая строки, можно сразу преобразовывать последовательности цифр в числа, а логические значения в true и false. Но это частности, ключевая информация все равно не появится, потому как ключ — это смысл, автоматом можно создать только числовой индекс.
Комплексные разделители
Вывод массива PHP в строку часто используется для служебных целей. Файл конфигурации традиционно записывают построчно, а имя от значения отделяет символ равно или двоеточие.
При таком решении вывод массива на PHP делается в файл, автоматически получается разделение строк и при обратном распознавании легко получаются ассоциативные массивы.
Читая файл, программист получает строки, а разбивая каждую строку по «=» или «:», получает имя и его значение. Очень востребованная манипуляция, хотя современнее использовать XML-нотацию на том простом основании, что кроме имен и значений можно хранить и восстанавливать дополнительные данные, например, атрибуты переменных.
В примере с абзацами (например, естественный текст для построения словаря или результат парсинга для создания выборки данных) важна не конкретная процедура преобразования строки в массив, а комплексное решение для всех абзацев или блоков информации.
Обычно такая задача потребует обратного решения, когда сформированный «комплект» данных нужно будет использовать для поиска в нем информации или для сборки обратно в строку.
Разборка и сборка строк — проверка данных
На PHP: массивы в строку — это точное решение. Если исходная информация могла иметь синтаксические ошибки, лишние пробелы, некорректные символы, то при разборке их не будет. Результат трансформации исходной информации по неписаным законам программирования выполняется строго формально, и результат будет четко разложен по полочкам.
Обратная процедура позволит создать правильную исходную строку. Если сопоставить объем исходной информации и результат обратного преобразования, то можно делать выводы о том, в каком месте были допущены ошибки или произошла потеря данных. На PHP длина массива в контексте исходной длины строки может позволить сделать нужные выводы.
Время, дата и метки событий
В разработке ответственных проектов, при создании объектов управления, например, временем или событиями, строка — это одно представление данных, а массив — это другое. Но в применении они эквивалентны.
Когда нужно выполнить математические или логические вычисления, программист манипулирует массивом, когда нужно сохранить данные, он использует строчный вариант.
Индексы доступа к полям базы данных — реальная практика совместного действия MySQL и PHP, массивы в строку = один индекс по строкам нескольких таблиц базы данных. Если база данных содержит десяток таблиц, а в каждой таблице строки могут быть выбраны по сочетанию имен (значений) в определенной комбинации, то сформировав массивы доступа к строкам, можно впоследствии иметь доступ к ним по алгоритму формирования индекса, а не по поиску в базе данных.
Преобразование массива в строку можно рассматривать как алгоритм формирования нужного индекса, в то время как содержание массива формируется под управлением совсем других событий или действий пользователя.
Слияние массивов
Функции PHP позволяют свободно манипулировать массивами. Но всегда возникают задачи сделать выборку уникальных данных или найти данные в массиве.
Первая задача решается итерационным путем: перебирается массив (или несколько массивов) и формируется строка уникальных значений — очевидное решение, но не самое эффективное.
Найти данные в массиве — тоже цикл, а если элементов много, то цикл будет довольно длинным и займет заметное время. Можно отправить массив в строку и при помощи функции strpos() найти вхождение требуемого элемента, но это обусловит проблему обнаружения ошибочного вхождения.
Например, искалось слово «лоток», а было найдено его вхождение в слове «молоток». Избавиться от таких ошибок можно, если все элементы массива сливать в строку по специальному разделителю, что позволит избежать неопределенности.
Если в строке оказались «[лоток]» и «[молоток]», то проблем с поиском не будет.
Но нет никакой гарантии, что на реальных объемах данных функция strpos() работает быстрее цикла, перебирающего элементы массива.
Объектное решение: массивы + строки
Лучшее решение, когда массив или строка самостоятельно выполняет правильное действие. Если несколько усложнить массивы и упростить строки, ведь первые — это частный случай объекта, а вторые — это традиционная сериализация, то каждый будет заниматься своим делом.
В нужный момент времени объект — это массив, а когда нужна строка, он будет строкой. При этом совершенно не обязательно иметь в объекте и массив, и строку одновременно. Можно построить уникальную структуру данных с быстрым доступом. А логику «массив» и «строка» вынести в методы объекта.
Объектно-ориентированный подход упрощает решение многих задач обработки строчной информации, позволяет не акцентировать внимание на массивах, циклах и функция обработки строк самого PHP.
Динамика смысла
Как строки, так и массивы — это реальный смысл реальной действительности, области применения, задачи. Нет такой задачи — отправить на PHP массивы в строку. Но есть задача получить абзац (предложение, фразу, слово, число…) на базе результатов, полученных в предыдущем алгоритме.
Предыдущий алгоритм несет в себе смысл, а точное выражение этого смысла содержится в массиве. Следующий этап алгоритма — трансформация смысла в другое представление, удобное для дальнейшей обработки или применения.
Рассматривая алгоритм, как динамику смысла и преобразований данных, можно формировать надежные, понятные и эффективные преобразования.
fb.ru