where 查询相关的问题

代码:

            ->when($title, function ($query) use ($title)
            {
                return $query->where('title', 'like', sprintf('%%%s%%', $title))->orWhere('id', $title);
            })

需求:

当前 Sql:
select * from `iblue_posts` where (`title` like ? or `id` = ? and `created_at` >= ? and `state` = ?) and `iblue_posts`.`deleted_at` is null order by `id` desc limit 20 offset 0
代码怎么改才能让SQL变成:
select * from `iblue_posts` where ((`title` like ? or `id` = ? )and `created_at` >= ? and `state` = ?) and `iblue_posts`.`deleted_at` is null order by `id` desc limit 20 offset 0
相信时间和变化
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 2
leo
->when($title, function ($query) use ($title) {
    return $query->where(function($query) use ($title) {
        return $query->where('title', 'like', sprintf('%%%s%%', $title))->orWhere('id', $title)
    });
})
6年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!