有一张表mytable,其中有一列叫name,假设有name属性分别为"ashiqwer","dfwmn","fghes"的三条记录,如何写sql语句,当前端传入"hw"时只能查询到第一条记录?
注意前端传入的字符串是任意的,要使用mybatis去数据库中查找
你这个需求应该是要做模糊匹配。
我理解查询的关键字一般是在前端输入的。
你在接受到前端输入后,把输入拆分成单个字符,在拼sql的时候每个字符中间都插入模糊匹配符号%。
譬如前端搜索框输入hw,拆分成单字符的模糊匹配串就成了%h%w%。
最终执行的sql样例如下:
select * from mytable where name like '%h%w%;
当你数据量较大(单表超过10W了)时,就需要把name字段加上全文索引,这样效率更高,有需要可以搜索mysql全文索引相关内容。
--解释sql大致为:
select * from mytable where Local('h',split(分割后的name属性,也就是ashiqwer))>0 and Local('w',split(分割后的name属性,也就是ashiqwer))>0
select * from mytable where Local('h',split(分割后的name属性,也就是dfwmn))>0 and Local('w',split(分割后的name属性,也就是ashiqwer))>0
select * from mytable where Local('h',split(分割后的name属性,也就是fghes))>0 and Local('w',split(分割后的name属性,也就是ashiqwer))>0
使用模糊匹配查询:select * from mytable where name like '%h%w%;