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 扩散模型sd.webui使用时报错“Nonetype”
  • ¥15 stm32流水灯+呼吸灯+外部中断按键
  • ¥15 将二维数组,按照假设的规定,如0/1/0 == "4",把对应列位置写成一个字符并打印输出该字符
  • ¥15 NX MCD仿真与博途通讯不了啥情况
  • ¥15 win11家庭中文版安装docker遇到Hyper-V启用失败解决办法整理
  • ¥15 gradio的web端页面格式不对的问题
  • ¥15 求大家看看Nonce如何配置
  • ¥15 Matlab怎么求解含参的二重积分?
  • ¥15 苹果手机突然连不上wifi了?
  • ¥15 cgictest.cgi文件无法访问