我在运行ubuntu的嵌入式设备上使用codeigniter 3rc2和Sqlite3。服务器和PHP配置正确。当我尝试从数据库中检索数据时,它返回一个空的查询对象。
我尝试过并将其排除在外的问题:
那我在这里做错了什么?
一些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
);
答案 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>";
}