dongza6247 2014-09-26 08:24
浏览 67
已采纳

Postgres,查询错误

I do one query and I have syntax error. But for me I do all right.

Where I have error?

Thanks!

$str = "Moscow";
$data = $ci->crud_model->query(
    'select * from "Cities" where  "defaultName" ilike  %'.$str.'%'
);

Query is : select * from "Cities" where "defaultName" ilike %Moscow%

  • 写回答

3条回答 默认 最新

  • douzhanyan5015 2014-09-26 08:53
    关注

    The LIKE/ILIKE operator takes two strings as its arguments. That is, the pattern has to be a quoted string, not just directly in the SQL query.

    So instead of:

    "defaultName" ilike %Moscow%
    

    You need:

    "defaultName" ilike '%Moscow%'
    

    In PHP, you should be (at the very least) escaping the input to avoid SQL Injection. Probably CodeIgniter has facilities for escaping, or using parameterised queries, but at the very least you should do this:

    $str = "Moscow";
    $data = $ci->crud_model->query(
        'select * from "Cities" where  "defaultName" ilike  \'%'.pg_escape_string($str).'%\''
    );
    

    EDIT Per Craig Ringer's comment, the correct ways to escape or build safe queries with CodeIgniter are covered in this answer.

    This is probably the simplest (note that the query parameter is automatically a string, and doesn't need extra quotes):

    $str = "Moscow";
    $data = $ci->crud_model->query(
        'select * from "Cities" where  "defaultName" ilike ?',
        array('%' . $str . '%')
    );
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 在grasshopper里DrawViewportWires更改预览后,禁用电池仍然显示
  • ¥15 NAO机器人的录音程序保存问题
  • ¥15 C#读写EXCEL文件,不同编译
  • ¥15 MapReduce结果输出到HBase,一直连接不上MySQL
  • ¥15 扩散模型sd.webui使用时报错“Nonetype”
  • ¥15 stm32流水灯+呼吸灯+外部中断按键
  • ¥15 将二维数组,按照假设的规定,如0/1/0 == "4",把对应列位置写成一个字符并打印输出该字符
  • ¥15 NX MCD仿真与博途通讯不了啥情况
  • ¥15 win11家庭中文版安装docker遇到Hyper-V启用失败解决办法整理
  • ¥15 gradio的web端页面格式不对的问题