Tôi đã tìm ra điều này bằng cách sửa đổi truy vấn được đưa ra trong giải pháp để nhận tất cả các ngày.
Truy vấn sau trả về tất cả các ngày và số lượng ID nếu có bất kỳ bản ghi nào:
select d.date, count(v.id) from
(select adddate('1970-01-01',t4.i*10000 + t3.i*1000 + t2.i*100 + t1.i*10 + t0.i) date from
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t0,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t1,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t2,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t3,
(select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t4) d
left join visitors v on d.date = v.date
where d.date between '2016-06-01' and '2016-06-30'
group by d.date
order by d.date
Được phép để nhận phạm vi ngày, hãy truy cập @ mark-bannister và một phép nối đơn giản trên kết hợp truy vấn để tìm kết quả và sắp xếp sẽ có được giải pháp.