Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум Регулярные Выражения

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: Парсер дампа базы данных

Сообщения:  [1-10]   [11-11] 

 
 автор: Atheist   (04.05.2008 в 22:25)   письмо автору
 
   для: AVS   (04.05.2008 в 22:24)
 

multiline mode.

Все модификаторы описаны тут: http://php.net/manual/ru/reference.pcre.pattern.modifiers.php

   
 
 автор: AVS   (04.05.2008 в 22:24)   письмо автору
 
   для: Atheist   (04.05.2008 в 22:17)
 

А что за модификатор "m"? Для чего он?

   
 
 автор: Atheist   (04.05.2008 в 22:17)   письмо автору
 
   для: AVS   (04.05.2008 в 22:10)
 

> Строка переводится просто как \n при создании дампа.

Тогда проще так:
<?php
$s 
preg_split("/;\s*$/m"$s, -1PREG_SPLIT_NO_EMPTY);
?>

   
 
 автор: AVS   (04.05.2008 в 22:10)   письмо автору
 
   для: Atheist   (04.05.2008 в 22:02)
 

А если каждый запрос будет отделен пустой строкой, то так разбить легче? Я мало работал с регулярными выражениями.

   
 
 автор: AVS   (04.05.2008 в 22:09)   письмо автору
 
   для: Atheist   (04.05.2008 в 22:02)
 

Строка переводится просто как \n при создании дампа.

   
 
 автор: Atheist   (04.05.2008 в 22:02)   письмо автору
 
   для: sil   (04.05.2008 в 21:56)
 

> проще было-бы разбить по пустым строкам
DROP ... и CREATE TABLE ... будут в одном блоке.

P.S.
to AVS
А в дампе в строковых значениях переводы строк прописаны через символы \r\n или могут быть фактически выражены байтами 0x0D 0x0A?

   
 
 автор: sil   (04.05.2008 в 21:56)   письмо автору
 
   для: AVS   (04.05.2008 в 21:48)
 

проще было-бы разбить по пустым строкам
<pre><?php
$txt 
"DROP TABLE IF EXISTS `users_online`; 
CREATE TABLE `users_online` ( 
  `ip` varchar(15) NOT NULL default '', 
  `time` bigint(20) NOT NULL, 
  PRIMARY KEY  (`ip`) 
) ENGINE=MyISAM DEFAULT CHARSET=cp1251; 

INSERT INTO `users_online` VALUES  
('127.0.0.1','1209675173'); 

DROP DATABASE IF EXISTS `forum`; 
CREATE DATABASE `forum` /*!40100 DEFAULT CHARACTER SET cp1257 */; 

"
;

print_r(
  
$array preg_split('#(?:\r?\n){2,}#s'$txt, -1PREG_SPLIT_NO_EMPTY)
    );


?></pre>

   
 
 автор: AVS   (04.05.2008 в 21:48)   письмо автору
 
   для: Atheist   (04.05.2008 в 21:44)
 

Вот -вот. На словах легко. А вот на деле прописать намного сложнее.

   
 
 автор: Atheist   (04.05.2008 в 21:44)   письмо автору
 
   для: ddhvvn   (04.05.2008 в 21:23)
 

> Берете зарезервированные слова, с которых может начинаться запрос и вытягиваете все до точки с запятой =)

...
INSERT INTO `tbl` VALUES(NULL, ';');
...

   
 
 автор: ddhvvn   (04.05.2008 в 21:23)   письмо автору
 
   для: AVS   (04.05.2008 в 20:04)
 

Берете зарезервированные слова, с которых может начинаться запрос и вытягиваете все до точки с запятой =)

   

Сообщения:  [1-10]   [11-11] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования