CodeIgniter是否支持PDO查询?给个例子
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了CodeIgniter是否支持PDO查询?给个例子,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2232字,纯文字阅读大概需要4分钟。
内容图文
![CodeIgniter是否支持PDO查询?给个例子](/upload/InfoBanner/zyjiaocheng/237/801d5560c7db4f078581cf6b44b7ff7c.jpg)
代码
仔细跟踪代码,发现有如下一句:
#文件 /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() 执行一次之后就不能再得到数据。所以导致后期就无法获得数据。
测试
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?希望能够给个例子!
回复内容:
配置CodeIgniter为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() 执行一次之后就不能再得到数据。所以导致后期就无法获得数据。
测试
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?希望能够给个例子!
可以拓展下driver
内容总结
以上是互联网集市为您收集整理的CodeIgniter是否支持PDO查询?给个例子全部内容,希望文章能够帮你解决CodeIgniter是否支持PDO查询?给个例子所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。