codeigniter 3.0rc2 Sqlite3没有返回任何数据

时间:2015-03-05 14:50:06

标签: php codeigniter sqlite embedded-linux cherokee

我在运行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 }

配置/ database.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
);

1 个答案:

答案 0 :(得分:0)

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

$query = $this->db->query('select * from users');
print_r($query);
foreach ($query->result_array() as $row)
{
    echo "<div>".print_r($row)."</div>";
}