欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

“class DBStatement extends PDOStatement” 是否可以在查询的时候,返回原始行数

程序员文章站 2022-05-21 20:13:23
...
“class DBStatement extends PDOStatement” 是不是可以在查询的时候,返回原始行数?
本帖最后由 rainxies 于 2013-03-11 10:20:33 编辑 我看到到处都有这段代码,但没有一个地方告诉有什么用?怎么使用?

class Database extends PDO
{
function __construct()
{
parent::__construct('mysql:dbname=test;host=localhost', 'root', '');
$this->setAttribute(PDO::ATTR_STATEMENT_CLASS, array('DBStatement', array($this)));
}
}

class DBStatement extends PDOStatement
{
public $dbh;

protected function __construct($dbh)
{
$this->dbh = $dbh;
$this->setFetchMode(PDO::FETCH_OBJ);
}

public function foundRows()
{
$rows = $this->dbh->prepare('SELECT found_rows() AS rows', array(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY => TRUE));
$rows->execute();
$rowsCount = $rows->fetch(PDO::FETCH_OBJ)->rows;
$rows->closeCursor();
return $rowsCount;
}
}


我的理解是实现了查询完成后,再调用foundRows可以返回原始记录集行数
可以避免分页时要执行2个SQL的问题(select count;select * )
不知是不是这样?
如果是,该如何调用啊?

请大虾们不吝赐教啊!!!感激涕零!!!

------解决方案--------------------
不要钻牛角尖
SELECT SQL_CALC_FOUND_ROWS * FROM tbl_name LIMIT 10;
SELECT FOUND_ROWS();

SELECT COUNT(*) FROM tbl_name
SELECT SQL_CALC_FOUND_ROWS * FROM tbl_name LIMIT 10;

同样是执行两次查询
在有 where 子句时,前者的效率要比后者高

php 的数据库函数不允许一次执行多条 SQL 指令,是为了防范 SQL攻击
比如($id 传入参数)
select * from tbl_name where id=$id
当$id = '1;delete from tbl_name';时,查询串变成
select * from tbl_name where id=1;delete from tbl_name
如果这个 delete from tbl_name 被执行的话,后果就可想而知了
虽然
select * from tbl_name where id='$id'
就可以防止这种情况的发生。
但是 php 并不能假定每个人都会将数值型数据用引号括起来


“class DBStatement extends PDOStatement” 是否可以在查询的时候,返回原始行数

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

相关文章

相关视频


网友评论

文明上网理性发言,请遵守 新闻评论服务协议

我要评论
  • “class DBStatement extends PDOStatement” 是否可以在查询的时候,返回原始行数
  • 专题推荐

    作者信息
    “class DBStatement extends PDOStatement” 是否可以在查询的时候,返回原始行数

    认证0级讲师

    推荐视频教程
  • “class DBStatement extends PDOStatement” 是否可以在查询的时候,返回原始行数javascript初级视频教程
  • “class DBStatement extends PDOStatement” 是否可以在查询的时候,返回原始行数jquery 基础视频教程
  • 视频教程分类