如何在一个月内选择数据库内容?

时间:2010-04-08 19:07:54

标签: codeigniter visitor-statistic

我在我的数据库中有以下表格命名的访问:

ID IP action_date | time_stamp

我使用此代码存储网站访问

/* Hits table has an auto-incrementing id and an ip field */

        // Grab client IP
        $ip = $this->input->ip_address();

        // Check for previous visits
        $query = $this->db->get_where('visits', array('ip' => $ip), 1, 0);
        $query = $query->row_array();

        if (count($query) < 1 )
        {
            // Never visited - add
            $this->db->insert('visits', array('ip' => $ip) );
        } 

它工作得很好。但是我的客户需要知道他们每个月有多少次访问。我怎样才能做到这一点 ?坦克。

1 个答案:

答案 0 :(得分:1)

如下:

$months = $this->db->select('
    COUNT(`id`) AS "count", 
    DATE_FORMAT(FROM_UNIXTIME(`action_date`),"%b-%Y") AS "month"',false
)
->group_by('month')
->where(array('ip' => $ip))
->order_by('action_date','desc')
->get('visits')->result();

应该为您提供如下数据:

+-------+----------+
| count | month    |
+-------+----------+
|   505 | Apr-2010 |
|   252 | Mar-2010 |
|   426 | Feb-2010 |
|   201 | Jan-2010 |
|   211 | Dec-2009 |
+-------+----------+