php - Laravel/Lumen 关系 - 加入条件检索错误的其他表

标签 php mysql laravel lumen eloquent

比较两个日期时,我在从数据库中检索一些数据时遇到了一个奇怪的问题。

数据库结构: 用户、预订、reservation_services、services_price_history

基于上表: 一个用户有很多预订,一个预订有很多服务,一个服务有很多价格历史记录。

我需要获取所有用户预订,然后根据预订日期找到服务价格。

问题是当我添加日期比较条件时它没有考虑到它

代码:

$users = User::with(['reservations' => function($query) use ($department_id, $date_start, $date_end) {

    // reservation services
    $query->with(['reservation_services' => function($query) {
        $query->join('reservations', 'reservation_services.reservation_id', 'reservations.id');
        $query->join('services', 'reservation_services.service_id', 'services.id');

        // Find the service price based on reservation date
        $query->join('services_price_history', function($query) {
            $query->on('reservations.salon_id', 'services_price_history.salon_id');
            $query->on('reservation_services.service_id', 'services_price_history.service_id');

            // this shoud be the condition that gives us the correct
            // price based on the reservation date
            $query->where('services_price_history.date_start', '<', 'reservations.date');
           // then we use order and limit 1
        });

        $query->select(
            'reservation_services.reservation_id',
            'reservation_services.service_id',
            'reservation_services.quantity',
            'services_price_history.price',
            'services_price_history.date_start',
            'services.name',
            DB::raw('(services_price_history.price * reservation_services.quantity) as total')
        );
        $query->orderBy('services_price_history.id', 'desc');
    }]);
}])->get();

这是输出:

[
   {
      "id":10,
      "first_name":"Mihaela",
      "last_name":"Radulescu",
      "reservations":[
         {
            "id":112,
            "salon_id":2,
            "client_id":161,
            "user_id":10,
            "date":"2017-10-31", // the reservation date
            "start":"10:00",
            "end":"12:00",
            "state_id":5,
            "notes":null,
            "price":"350.00",
            "reservation_services":[
               {
                  "reservation_id":112,
                  "service_id":89,
                  "quantity":1,
                  "price":"400.00",
                  "date_start":"2017-11-02", // this is wrong
                  "name":"Tratament ANTI AGE",
                  "total":"400.00"
               },
               {
                  "reservation_id":112,
                  "service_id":89,
                  "quantity":1,
                  "price":"350.00",
                  "date_start":"2017-10-19", // this is ok
                  "name":"Tratament ANTI AGE",
                  "total":"350.00"
               }
            ],
            "reservation_products":[

            ]
         },
      ]
   },
],

我真的不知道为什么,但是这行代码

$query->where('services_price_history.date_start', '<', 'reservations.date');

没有正常工作,因为 '2017-11-02'高于'2017-10-31'但它显示在结果中。

非常感谢。

最佳答案

代替:

$query->where('services_price_history.date_start', '<', 'reservations.date');

使用:

$query->whereRaw('services_price_history.date_start < reservations.date');

关于php - Laravel/Lumen 关系 - 加入条件检索错误的其他表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47083074/

相关文章:

php - 使用mysql php搜索和匹配单词

php - 在数据库中搜索多段线坐标中的位置

php - Laravel 返回日期参数为 0 的空结果

laravel - 如何在不要求用户登录 Laravel 的情况下验证电子邮件

php - 在 bash 脚本中使用 for 和 if 循环

PHPUnit - fatal error :当测试类为空时,方法 PHPUnit_Framework_AssertionFailedError::__toString() 不得抛出异常?

mysql - 通过iOS应用程序将数据从json(php webservice)修改为mysql

php - 如果电子邮件未通过验证,如何限制 Laravel 中的用户登录

javascript - iFrame 内自动登录

javascript - 获取变量传递给 php 表单