1

我根据用户选择的日期从数据库中提取数字数据。出于某种原因,当我选择我的函数来提取今天的所有数据(没有数据)时,它仍然形成一个空值数组。

我认为问题在于 select_sum() 或 where() 函数。这是我的 CI 查询:

    $this->db   
            ->select_sum('column1')
            ->select_sum('column2')
            ->select_sum('column3')
                ->where('created_at >=', date('Y-m-d'));
            $query = $this->db->get('table_name');

这是我的 foreach 循环,它将所有选定的数据拉入一个数组中,以便在整个页面中使用:

$popular_items_array = array();
        foreach ($query->result() as $key => $row) 
        {   
            if ($row == NULL) {
                echo "Error populating table.";
            } else {
             $popular_items_array = $row;
            }
        }

为了查看数据,我做了:

echo json_encode($popular_items_array);

结果表明:

{"column1":null,"column2":null,"column3":null}

如果我选择不同的时间范围(数据在设定日期之前实际存在),则相同的 JSON 回显将显示现有数据。我不明白的是,为什么查询返回任何东西?为什么不只是失败?以及如何运行检查/循环来捕获此问题,并显示一条错误消息,让用户知道该日期不存在数据?

4

2 回答 2

3

如果您不希望得到任何记录,您可以将您的代码修改为:

$this->db   
    ->select_sum('column1')
    ->select_sum('column2')
    ->select_sum('column3')
        ->where('created_at >=', date('Y-m-d'))
        ->having('count(*) > 0');
$query = $this->db->get('table_name');
于 2013-07-01T18:54:23.750 回答
1

这就是聚合函数(如sum()avg()max())的工作方式,它们将从结果集中返回聚合值。如果结果集是空的,他们将聚合它。这会导致很多混乱和错误报告,但这应该是这样工作的,可以在 dba.stackexchange.com 找到更详细的解释

您可以使用COALESCE将这些值替换为NULL更有用的值,或者您可以添加 acount()以便了解用于生成sum()s 的行数。

奇怪的是,如果您添加一个组,它将按您的预期工作(至少使用 mysql):

SELECT sum(id) sum_id FROM `users` WHERE 0 # => array( array('sum_id' => null) )

但:

SELECT sum(id) FROM `users` WHERE 0 GROUP BY null # => array()
于 2013-07-01T18:40:47.253 回答