首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >想要在Laravel的时间范围内获得结果

想要在Laravel的时间范围内获得结果
EN

Stack Overflow用户
提问于 2018-06-03 21:08:53
回答 1查看 68关注 0票数 0

我有一些记录,我想从他们那里获得记录的项目不在给定的时间范围内,这是我的代码,我已经尝试,但没有成功

代码语言:javascript
复制
$other_hour_trade = DB::table('finaltrade')
        ->join('exchanges', 'finaltrade.exchange_id', '=', 'exchanges.id')
        ->select('finaltrade.*')
        ->where('finaltrade.user_id', $user_id)
        ->whereNotBetween('finaltrade.created_at', [DB::raw('exchanges.start_time'), DB::raw("ADDTIME(exchanges.start_time, '01:00:00')")])
        ->whereNotBetween('finaltrade.created_at', [DB::raw('exchanges.close_time'), DB::raw("SUBTIME(exchanges.close_time, '01:00:00')")])
        ->get();

'finaltrade.created_at‘是日期时间字段,'exchanges.start_time’和'exchanges.close_time‘是唯一的时间字段

我连接了两个表以获得结果

EN

回答 1

Stack Overflow用户

发布于 2018-06-03 21:18:04

我不知道如何直接使用whereNotBetween来实现这一点,但是既然您已经尝试在当前代码中使用一些原始的SQL,为什么不直接使用whereRaw

代码语言:javascript
复制
$other_hour_trade = DB::table('finaltrade')
    ->join('exchanges', 'finaltrade.exchange_id', '=', 'exchanges.id')
    ->select('finaltrade.*')
    ->where('finaltrade.user_id', $user_id)
    ->whereRaw("finaltrade.created_at NOT BETWEEN exchanges.start_time AND ADDTIME(exchanges.start_time, '01:00:00')")
    ->whereRaw("finaltrade.created_at NOT BETWEEN exchanges.close_time AND SUBTIME(exchanges.close_time, '01:00:00')")
    ->get();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50666765

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档