具有条件的laravel查询生成器

Man*_*rma 8 php mysql date laravel chart.js

我正在实现一个查询,使用chartjs绘制一个多线图.我有一系列日期

["2016-10-16","2016-10-17","2016-10-18","2016-10-19","2016-10-20","2016-10-21","2016-10-22","2016-10-23","2016-10-24","2016-10-25","2016-10-26","2016-10-27","2016-10-28","2016-10-29","2016-10-30","2016-10-31","2016-11-01","2016-11-02","2016-11-03","2016-11-04","2016-11-05","2016-11-06","2016-11-07","2016-11-08","2016-11-09","2016-11-10","2016-11-11","2016-11-12","2016-11-13","2016-11-14","2016-11-15","2016-11-16"]
Run Code Online (Sandbox Code Playgroud)

此数组的日期介于"2016-11-16"和"2016-10-16"之间.

我已经创建了一个模型Tickets,并且我写了一个查询来获取分组的票数tickets.status.

$join = $this->tickets();
$tickets = $join
         ->when($category, function($query) use ($category) {
             $ranges = $this->dateRange($category);
             return $query->whereBetween('tickets.created_at', $ranges);
         })
         ->select(DB::raw('COUNT(tickets.id) as tickets'), 'ticket_status.name as name', 'tickets.created_at')
         ->groupBy('ticket_status.name', 'tickets.created_at')
         ->get();
Run Code Online (Sandbox Code Playgroud)

执行此查询我得到了

[
    {
        "tickets":"1",
        "name":"Closed",
        "created_at":"2016-11-08 14:07:32"
    },
    {
        "tickets":"1",
        "name":"Open",
        "created_at":"2016-11-08 14:07:32"
    },
    {
        "tickets":"1",
        "name":"Open",
        "created_at":"2016-11-11 12:24:39"
    },
    {
        "tickets":"1",
        "name":"Open",
        "created_at":"2016-11-11 12:26:38"
    },
    {
        "tickets":"1",
        "name":"Open",
        "created_at":"2016-11-11 12:27:04"
    },
    {
        "tickets":"1",
        "name":"Open",
        "created_at":"2016-11-11 12:27:49"
    },
    {
        "tickets":"1",
        "name":"Open",
        "created_at":"2016-11-11 12:28:47"
    },
    {
        "tickets":"1",
        "name":"Resolved",
        "created_at":"2016-11-08 14:07:32"
    }
]
Run Code Online (Sandbox Code Playgroud)

如果$label[0] != $tickets.created,票证和名称将为空但应具有日期

请帮我看一下输出

[
    [
        'tickets'=>0,
        'name'=>null,//tickets don't have this date
        'created_at'=>'2016-10-16'
    ],
    [
        'tickets'=>0,
        'name'=>null,//tickets don't have this date
        'created_at'=>'2016-10-15'
    ],
    [
        'tickets'=>1,
        'name'=>'closed',//on this date 1 closed ticket
        'created_at'=>'2016-10-14'
    ],
    [
        'tickets'=>3,
        'name'=>'open',//on this date 3 open ticket
        'created_at'=>'2016-10-14'
    ],
    [
        'tickets'=>2,
        'name'=>'resolved',//on this date 2 resolved ticket
        'created_at'=>'2016-10-14'// on 2016-10-14 has three different tickets
    ],
    ...........
]
Run Code Online (Sandbox Code Playgroud)

请帮我找一个解决方案.提前致谢.

SoW*_*dly 1

您需要将其转换为 Laravel/Eloquent,但这是一个原始数据库查询,可以满足您的需求。

假设的表格/数据

Table: tbl_dates
id | date
1    2016-11-17 00:00:00
2    2016-11-18 00:00:00
...etc...

Table: tickets
id | created_at
1    2016-11-18 12:34:56
2    2016-11-18 01:23:45
3    2016-11-18 02:34:56

Table: ticket_status
ticket_id | name
1           Open
2           Closed
3           Closed
Run Code Online (Sandbox Code Playgroud)

询问:

SELECT 
  COUNT(tickets.id) AS tickets,
  ticket_status.name, 
  DATE(tbl_dates.date) AS ticket_date
FROM 
  tbl_dates
LEFT JOIN 
  tickets 
ON
  (DATE(tbl_dates.date) = DATE(tickets.created_at))
LEFT JOIN
  ticket_status
ON
  (tickets.id = ticket_status.ticket_id)
GROUP BY 
  ticket_status.name
ORDER BY 
  ticket_date
ASC
Run Code Online (Sandbox Code Playgroud)

结果:

 tickets | name | ticket_date
 0         NULL   2016-11-17
 1         Open   2016-11-18
 2         Closed 2016-11-18
Run Code Online (Sandbox Code Playgroud)

基本上,要在纯 MySQL 中执行此操作,您需要一个包含所有日期的表。查看这篇 SO 帖子,了解生成日期表的简单方法。