我收到错误,
Warning: preg_replace(): No ending delimiter '#' found
在这一行,
$sql = preg_replace("\n#[^\n]*\n", "\n", $sql);
关于此功能,
function split_sql($sql) {
$sql = trim($sql);
$sql = preg_replace("\n#[^\n]*\n", "\n", $sql);
$buffer = array();
$ret = array();
$in_string = false;
for($i=0; $i<strlen($sql)-1; $i++) {
if($sql[$i] == ";" && !$in_string) {
$ret[] = substr($sql, 0, $i);
$sql = substr($sql, $i + 1);
$i = 0;
}
if($in_string && ($sql[$i] == $in_string) && $buffer[1] != "\\") {
$in_string = false;
}
elseif(!$in_string && ($sql[$i] == '"' || $sql[$i] == "'") && (!isset($buffer[0]) || $buffer[0] != "\\")) {
$in_string = $sql[$i];
}
if(isset($buffer[1])) {
$buffer[0] = $buffer[1];
}
$buffer[1] = $sql[$i];
}
if(!empty($sql)) {
$ret[] = $sql;
}
return($ret);
}
答案 0 :(得分:2)
分隔符必须是非字母数字,非空白字符。由于这个原因,它会将#
视为分隔符,因此会查找另一个但无法找到它。
尝试preg_replace("/\n#[^\n]*\n/","\n",$sql);