PHP修剪不起作用

PHP修剪不起作用,php,trim,Php,Trim,我试图用trim去掉sql语句后面的逗号,但它似乎不起作用 if(isset($_POST['report'])){ //==== $sql = 'INSERT INTO weekly_repo ( hospnme, disease, week, under5, above5, dat) VALUES '; $week = intval($_POST['current_week']); $diseases = $_POST['diseases']; fo

我试图用trim去掉sql语句后面的逗号,但它似乎不起作用

if(isset($_POST['report'])){
    //====
    $sql = 'INSERT INTO weekly_repo ( hospnme, disease, week, under5, above5, dat) VALUES ';
    $week = intval($_POST['current_week']);
    $diseases = $_POST['diseases'];

    foreach($diseases as $disease){

        $sql .= ' ( "' . filterString($_POST['hospital']). '", "' . filterString($disease['disease']) . '", ' . $week . ', ' . intval($disease['under_5']) . ', ' . intval($disease['over_5']) . ', NOW()), ';

    }
    $sql = trim($sql, '\,');
    // ended up doing this
    //$sql = substr($sql, 0, strrpos($sql, ',')) . ';';
    $stmt = $conn->query($sql);

}

您不需要转义逗号。更好的方法可能是构造一个数组,然后
内爆()


去掉斜杠。你不需要它$sql=trim($sql,“,”);或者只使用
$sql=substr($sql,-1)
。因为有额外的空间,所以需要
rtrim(…,“,”)
。更好的方法是,构建一个数组,在拥有所有数据对时将其加入字符串。这避免了修剪的麻烦。谢谢朋友们!但是在PHP手册中,它们逃逸了
foreach($diseases as $disease){
    $sql[] = ' ( "' . filterString($_POST['hospital']). '", "' . filterString($disease['disease']) . '", ' . $week . ', ' . intval($disease['under_5']) . ', ' . intval($disease['over_5']) . ', NOW()), ';
}
$sql = implode(',', $sql);