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

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

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

 

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

вид форума:
Линейный форум Структурный форум

тема: Парсер дампа базы данных
 
 автор: AVS   (04.05.2008 в 20:04)   письмо автору
 
 

Здравствуйте!

В файле есть дамп базы вида:


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 */;

DROP TABLE IF EXISTS `phpbb3_acl_groups`;
CREATE TABLE `phpbb3_acl_groups` (
  `group_id` mediumint(8) unsigned NOT NULL default '0',
  `forum_id` mediumint(8) unsigned NOT NULL default '0',
  `auth_option_id` mediumint(8) unsigned NOT NULL default '0',
  `auth_role_id` mediumint(8) unsigned NOT NULL default '0',
  `auth_setting` tinyint(2) NOT NULL default '0',
  KEY `group_id` (`group_id`),
  KEY `auth_opt_id` (`auth_option_id`),
  KEY `auth_role_id` (`auth_role_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;


Читаю файл целиком через file_get_contents().

Мне надо поместить каждый отдельный SQL запрос в массив, т.е. 1 запрос = 1 ячейка массива.
Помогите составить регулярное выражение для preg_match(). Спасибо.

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

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

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

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

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

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

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

   
 
 автор: 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>

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

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

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

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

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

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

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

   
 
 автор: 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:24)   письмо автору
 
   для: Atheist   (04.05.2008 в 22:17)
 

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

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

multiline mode.

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

   
Rambler's Top100
вверх

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