计算由一个 SELECT 语句返回的行数
对于大多数数据库,PDOStatement::rowCount()
不能返回受一条 SELECT 语句影响的行数。替代的方法是,使用PDO::query()
来发出一条和原打算中的SELECT语句有相同条件表达式的SELECT COUNT(*)
语句,然后用 PDOStatement::fetchColumn()
来取得下一行。这样应用程序才能正确执行。
<?php $sql = "SELECT COUNT(*) FROM fruit WHERE calories > 100"; if ($res = $conn->query($sql)) { /* 检查符合 SELECT 语句的行数 */ if ($res->fetchColumn() > 0) { /* 发出一条真正的 SELECT 语句并操作返回的结果 */ $sql = "SELECT name FROM fruit WHERE calories > 100"; foreach ($conn->query($sql) as $row) { print "Name: " . $row['NAME'] . "\n"; } } /* 没有匹配的行 -- 执行其他 */ else { print "No rows matched the query."; } } $res = null; $conn = null; ?>
以上实例输出结果为:
apple
banana
orange
pear
总结
Copyright © 2019- yrrf.cn 版权所有 赣ICP备2024042794号-2
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务