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

CodeIgniter 是不是支持PDO 查询?还是本来就不支持

程序员文章站 2022-05-27 13:17:41
...
CodeIgniter 是否支持PDO 查询?还是本来就不支持?
本帖最后由 default7 于 2014-11-15 19:34:55 编辑 配置CodeIgniter 的database 连接方式为PDO 类型,但是怎么都查询不到数据,却可以查处有多少记录!

自带代码
仔细跟踪代码,发现有如下一句:

#文件 /system/database/drivers/pdo/pdo_driver.php
function _execute($sql)
{
$sql = $this->_prep_query($sql);
$result_id = $this->conn_id->prepare($sql);

if (is_object($result_id) && $result_id->execute())
{
if (is_numeric(stripos($sql, 'SELECT')))
{
$this->affect_rows = count($result_id->fetchAll());
}
else
{
$this->affect_rows = $result_id->rowCount();
}
}
else
{
$this->affect_rows = 0;
return FALSE;
}

return $result_id;
}




问题原因

$this->affect_rows = count($result_id->fetchAll());


这里的CI使用 $result_id->fetchAll() 来统计符合条件的个数,但是这个 fetchAll() 执行一次之后就不能再得到数据。所以导致后期就无法获得数据。


替代方法

//怎么都不会有结果,但是却会有条数
class User_model extends CI_Model {
public function getList(){
$sql = "select * from #@__user ";
return $this->db->query($sql)->result_array();
}
}



//这样写就会有结果记录,但是默认的 $this->db->query($sql) .. 却又成摆设了!
class User_model extends CI_Model{
public function getList(){
$sql = "select * from ci_user";
$stmt = $this->db->conn_id->prepare($sql);
$stmt->execute();
return $stmt->fetchAll();
}
}




应该是不支持,但是官网下载的里面却带有PDO包。
想确认的是,codeigniter是否真的支持PDO?希望能够给个例子!

------解决思路----------------------
        if (is_object($result_id) && $result_id->execute())
{
if (is_numeric(stripos($sql, 'SELECT')))
{
$this->affect_rows = count($result_id->fetchAll());
$result_id->execute(); //再执行一次
}
else
{
$this->affect_rows = $result_id->rowCount();
}
}

虽然 rowCount 方法可能对某些数据库的 select 指令无效,但对于 mysql 的 select 指令还是有效的
所以把
$this->affect_rows = count($result_id->fetchAll());
改为
$this->affect_rows = $result_id->rowCount();
也是可以的
何况他对常见数据库都单独提供了操作类
CodeIgniter 是不是支持PDO 查询?还是本来就不支持

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

相关文章

相关视频


网友评论

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

我要评论
  • CodeIgniter 是不是支持PDO 查询?还是本来就不支持
  • 专题推荐