0

如果参数中有空格,则将参数传递给 sql 查询时出现问题。代码是

$statement="select  di_timestamp, di_item_value
from data_item
where
fk_fc_id=(select fc_id 
        from field_column
        where 
        fc_description ilike :sensor
        and
        fk_mds_id=( select mds_id 
                    from monitored_data_set
                    where fk_pa_id=(select pa_id 
                        from pilot_ambient 
                        where   
                        pa_ambient_name ilike :room
                        and 
                        fk_sp_id=(
                            select sp_id 
                            from School_Pilot 
                            where sp_description ilike :name
                            )
                        )
                    )
                )";
$query = $databaseConn->prepare($statement);
$query->execute(array(':sensor'=>$sensor,':room'=>$room,':name' => '%'.$school.'%'));

但是,如果传感器包含任何空格,则查询失败。我该如何解决这个问题?我试过在参数中加上引号,在查询中加上引号,但没有任何效果。

4

1 回答 1

1

您可以在准备好的语句参数中传递空格字符,无需引号或任何特殊注意。

这是一个演示:

<?
$pdo = new PDO('pgsql:dbname=test');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$query = "SELECT 1 WHERE 'abc de' ilike :pattern";
try {
  $stmt = $pdo->prepare($query);
  $stmt->execute(array(":pattern"=>'ABc %'));
  var_dump($stmt->fetchAll());
}
catch(PDOException $e){
   echo "Error".  $e->getMessage();
}
?>

它不会产生错误并显示正确的结果:

数组(1){
  [0]=>
  数组(2){
    [“?列?”]=>
    整数(1)
    [0]=>
    整数(1)
  }
}

如果要匹配的列的数据类型是 typeCHAR(n)而不是VARCHAR(n)or TEXT,请注意尾随空格被视为不重要。

于 2013-11-02T14:44:45.023 回答