【发布时间】:2019-10-01 23:00:19
【问题描述】:
假设我有 3 个用户,然后我想用“罗伯特”的名字进行过滤
“阿尔伯特·罗伯特·威尔逊”、“罗伯特·梅根”、“威廉·乔”
我希望我的 sql 查找包含 Robert 的所有记录,但以 Robert Magan 开头的方式排序,因为它以关键字开头,然后是 Albert Robert Wilso
【问题讨论】:
假设我有 3 个用户,然后我想用“罗伯特”的名字进行过滤
“阿尔伯特·罗伯特·威尔逊”、“罗伯特·梅根”、“威廉·乔”
我希望我的 sql 查找包含 Robert 的所有记录,但以 Robert Magan 开头的方式排序,因为它以关键字开头,然后是 Albert Robert Wilso
【问题讨论】:
您应该在问题中提供示例模型/表名称和列名称。但是假设模型是User,列是name。我认为这样的事情会起作用(未经测试):
User::where('name', 'like', '%Robert%')->orderBy(\DB:raw('POSITION("Robert" IN name)', 'asc')->get();
但请注意不要造成 SQL 注入漏洞!
【讨论】:
Syntax error or access violation near ') asc, created_at desc limit 20 offset 0'
POSITION("Robert" IN name) 编辑你的答案
你可以使用一些原始的 mysql 和字符串操作来解决这个问题,以便按第一个单词排序。
另一种方法是将关键字和剩余的或完整的字符串分成两个单独的列,然后按关键字列排序。
【讨论】: