-3

我得到一个错误,

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);
}
4

1 回答 1

2

分隔符必须是非字母数字、非空白字符。由于这个原因,它将 the#视为分隔符,因此寻找另一个并且找不到它。

尝试preg_replace("/\n#[^\n]*\n/","\n",$sql);

于 2013-01-21T16:21:23.813 回答