Laravel:日期介于零值之间
Laravel: Date between with zero values
我正在尝试获取给定日期范围内的数据库值。问题是,我也在努力实现缺失值。如果我有第 1 天和第 3 天的值,我要求第 1-5 天的值,我想得到这样的结果:
1 -> 值
2 -> NULL / 0
3 -> 值
4 -> NULL / 0
5 -> NULL / 0
好的,我知道如何仅使用 MySQL 和左连接中的这个临时 table 来解决这个问题:
(select adddate('1970-01-01',t4.i*10000 + t3.i*1000 + t2.i*100 + t1.i*10 + t0.i) selected_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) v
不幸的是,我不确定如何将其包含在 Eloquent ORM 中。
目前我在想这样的事情:
$weekclockings = $shift->clockings()->leftJoin(function($query)
{
$query->raw($aboveQuery);
}, "v.selected_date", ">", "timeclocked.time_in")
但这不起作用,只是给了我 "ErrorException in Grammar.php line 33: Object of class Closure could not be converted to string"。
所以,这可能不是最好的方法。有人知道如何实现吗?
我不知道这里的 clockings()
是什么 - 可能是一个范围,但是要在连接中使用原始 SQL,您应该使用:
$weekclockings = $shift->clockings()->leftJoin(\DB::raw($aboveQuery), "v.selected_date", ">", "timeclocked.time_in");
我正在尝试获取给定日期范围内的数据库值。问题是,我也在努力实现缺失值。如果我有第 1 天和第 3 天的值,我要求第 1-5 天的值,我想得到这样的结果:
1 -> 值
2 -> NULL / 0
3 -> 值
4 -> NULL / 0
5 -> NULL / 0
好的,我知道如何仅使用 MySQL 和左连接中的这个临时 table 来解决这个问题:
(select adddate('1970-01-01',t4.i*10000 + t3.i*1000 + t2.i*100 + t1.i*10 + t0.i) selected_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) v
不幸的是,我不确定如何将其包含在 Eloquent ORM 中。 目前我在想这样的事情:
$weekclockings = $shift->clockings()->leftJoin(function($query)
{
$query->raw($aboveQuery);
}, "v.selected_date", ">", "timeclocked.time_in")
但这不起作用,只是给了我 "ErrorException in Grammar.php line 33: Object of class Closure could not be converted to string"。
所以,这可能不是最好的方法。有人知道如何实现吗?
我不知道这里的 clockings()
是什么 - 可能是一个范围,但是要在连接中使用原始 SQL,您应该使用:
$weekclockings = $shift->clockings()->leftJoin(\DB::raw($aboveQuery), "v.selected_date", ">", "timeclocked.time_in");