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
相信时间和变化
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 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)
    });
})
4年前 评论

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