dsce23640 2013-11-05 12:13
浏览 48
已采纳

使用PDO和MySql一样使用%%

I failed with this. Despite all the answers here, I just cannot get this right. How do I bind a search term when using like in mysql with php's pdo?

$searchTerm = 'kfc';
$stmt = $conn->prepare("select name from table where name like CONCAT('%',:searchTerm,'%')");
$stmt->bindParam(':searchTerm', $searchTerm);

or 

$searchTerm = 'kfc';
$stmt = $conn->prepare("select name from table where name like %:searchTerm%");
$stmt->bindParam(':searchTerm', $searchTerm);

Neither will work for me. How do I get this correct?

  • 写回答

2条回答 默认 最新

  • dongyan7876 2013-11-05 12:18
    关注

    You're missing the LIKE clause in both the queries. bindParam will automatically take care of all the quoting, so you don't need to add single-quotes around the search term.

    This should work:

    $searchTerm = 'kfc%';
    $stmt = $conn->prepare("select name from table where name LIKE :searchTerm");
    $stmt->bindParam(':searchTerm', $searchTerm);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥50 成都蓉城足球俱乐部小程序抢票