iou3344 2022-12-27 01:32 采纳率: 85.2%
浏览 56
已结题

PHP+MYSQL模糊查询出错的原因是什么呢?

<?php  
header("Content-Type: text/html;charset=utf-8");
$dsn = 'mysql:dbname=dmm; host=127.0.0.1';
$pdo = new PDO($dsn, 'root', 'root');
$sql = "select * from data_content_166 WHERE 标题 LIKE '%大学%' AND 标题 LIKE '%意义%' AND 类别 LIKE '%教育%' AND 类别 LIKE '%高校%' AND 作者 LIKE '%老师%' AND 作者 LIKE '%李%' ";
$sth = $pdo->prepare($sql);
$sth->execute();
$data = $sth->fetchAll();
?>
<?php
foreach($data as $key=>$wenzhang){
?>
<p><?php echo $wenzhang['标题']; ?></p>
<?php
}
?>

以上代码中的sql在cmd的控制台页面查询是有结果的,但是在PHP页面就查不到,折腾了一天搞不定啊。

注意,各个字段单条件查询时时,是可以搜到结果的,应该和字符编码没关系。
$sql = "select * from data_content_166 WHERE 标题 LIKE '%大学%' AND 类别 LIKE '%教育%' AND 作者 LIKE '%老师%' ";
这时候,PHP里面是可以搜到结果的。

img

  • 写回答

4条回答 默认 最新

  • zhu_xiaotong 2022-12-27 13:57
    关注

    确保查询条件的拼写和语法正确后看:
    1、在 PHP 中使用 var_dump() 或者 print_r() 函数查看 $sth->fetchAll() 返回的数组是否为空。
    2、在 PHP 中使用 $sth->rowCount() 函数查看查询是否返回了任何行。如果返回的行数为 0,说明查询条件不满足任何记录。(就可能是你字符编码的问题)
    3、在 PHP 中使用 $sth->debugDumpParams() 函数查看查询语句是否正确。
    4、在 MySQL 中使用 EXPLAIN 语句查看查询的执行计划。如果查询的表不存在,或者查询的字段不存在,MySQL 将会报错。
    5、在 MySQL 中使用 DESCRIBE 语句查看表的结构。确保表中包含了您要查询的字段。

    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 12月27日
  • 赞助了问题酬金15元 12月27日
  • 修改了问题 12月27日
  • 修改了问题 12月27日
  • 展开全部

悬赏问题

  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计