0

我在运行 ubuntu 的嵌入式设备上使用 codeigniter 3rc2 和 Sqlite3。服务器和php配置正确。当我尝试从数据库中检索数据时,它返回一个空查询对象。

我尝试并排除的问题:

  • 使用 Python 时访问和读取数据库有效(数据库中有数据)
  • codeigniter 日志中没有错误
  • 将 /config/database.php 更改为不存在的文件时,codeigniter 按预期抛出错误
  • 使用 querybuilder 或直接 sql 时,结果相同,没有数据
  • 将 SQL 语法更改为不存在的表时,codeiginiter 会按预期抛出错误。

那么我在这里做错了什么?

一些codeigniter代码

$q_user = $this->db->query('select * from users');
var_dump($q_user);

导致浏览器窗口

object(CI_DB_sqlite3_result)#25 (8) { ["conn_id"]=> object(SQLite3)#22 (0) { } ["result_id"]=> object(SQLite3Result)#24 (0) { } ["result_array"]=> array(0) { } ["result_object"]=> array(0) { } ["custom_result_object"]=> array(0) { } ["current_row"]=> int(0) ["num_rows"]=> NULL ["row_data"]=> NULL }

配置/数据库.php

$active_group = 'default';
$query_builder = TRUE;

$db['default'] = array(
    'dsn'   => '',
'hostname' => '',
'username' => '',
'password' => '',
'database' => '/var/qcd/qcd.db',
'dbdriver' => 'sqlite3',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => TRUE,
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'autoinit' => TRUE,
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE
);
4

1 回答 1

0

好像我读错了对象。打印 $q_user 对象只显示其中的对象,而不是数据数组。当我使用此代码时,它会显示检索到的数据

$query = $this->db->query('select * from users');
print_r($query);
foreach ($query->result_array() as $row)
{
    echo "<div>".print_r($row)."</div>";
}
于 2015-03-06T10:12:36.183 回答