doucan8276 2017-11-10 18:33
浏览 301
已采纳

使用preg_match从create table语句中获取SQL表名

I'm really bad with regex but I'm desperately trying to extract table names from SQL "create table" statements, I have something like this:

db.sql:

CREATE TABLE `users` (
  `user_id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL,
  `email` varchar(255) NOT NULL
   PRIMARY KEY (`user_id`)
);

There could be multiple create table statements, I want to get all table names for each of these, I tried using this regex:

<?php

$sql = file_get_contents('db.sql');
preg_match('/create\s+table\s+\`?\w+`/i', $sql, $tables);
var_dump($tables);

It sort of works:

array:1 [▼
  0 => "CREATE TABLE `ps_advbisn_subscription`"
]

However I want the return the match without the "create table" part, I read about look aheads and behinds and tried this:

<?php

$sql = file_get_contents('db.sql');
preg_match('/(?<=create\s+table\s+\`?)(\w+)(?=`?)/i', $sql, $tables);
var_dump($tables);

But all I get is null. What am I missing here ?

  • 写回答

1条回答 默认 最新

  • dto52236 2017-11-10 18:37
    关注

    All you need to do is to catch a table name, it is done with ():

    preg_match('/create\s+table\s+\`?(\w+)`/i', $sql, $tables);
    var_dump($tables[1])
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 数学建模招标中位数问题
  • ¥15 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 HLs设计手写数字识别程序编译通不过
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 TYPCE母转母,插入认方向
  • ¥15 如何用python向钉钉机器人发送可以放大的图片?
  • ¥15 matlab(相关搜索:紧聚焦)
  • ¥15 基于51单片机的厨房煤气泄露检测报警系统设计