关于#mysql的问题,通过字符串中的非连续字符组合查询符合条件的记录

有一张表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全文索引相关内容。

  1. 这么业务上或者设计表结构不太符合常规
  2. 可以实现,把name属性按照逗号分隔,hw按照字符分割,用每个字符用LOCATE函数判断是否包含着name属性(也就是逗号分割后的每个字符串中)
--解释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%;