【问题标题】:codeigniter 3.0rc2 Sqlite3 not returning any datacodeigniter 3.0rc2 Sqlite3 不返回任何数据
【发布时间】:2015-05-06 23:45:32
【问题描述】:

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

config/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
);

【问题讨论】:

    标签: php codeigniter sqlite embedded-linux cherokee


    【解决方案1】:

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

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

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-03-14
      • 1970-01-01
      • 2012-07-13
      • 2017-11-23
      • 2021-12-13
      • 2016-12-06
      • 2011-04-04
      • 2015-06-09
      相关资源
      最近更新 更多