有一张表mytable,其中有一列叫name,假设有name属性分别为"ashiqwer","dfwmn","fghes"的三条记录,如何写sql语句,当前端传入"hw"时只能查询到第一条记录?
注意前端传入的字符串是任意的,要使用mybatis去数据库中查找
关于#mysql的问题,通过字符串中的非连续字符组合查询符合条件的记录
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
3条回答 默认 最新
爱吃苦瓜的猿 2022-08-20 07:48关注你这个需求应该是要做模糊匹配。
我理解查询的关键字一般是在前端输入的。
你在接受到前端输入后,把输入拆分成单个字符,在拼sql的时候每个字符中间都插入模糊匹配符号%。
譬如前端搜索框输入hw,拆分成单字符的模糊匹配串就成了%h%w%。
最终执行的sql样例如下:select * from mytable where name like '%h%w%;当你数据量较大(单表超过10W了)时,就需要把name字段加上全文索引,这样效率更高,有需要可以搜索mysql全文索引相关内容。
本回答被题主选为最佳回答 , 对您是否有帮助呢?评论 打赏 举报 编辑记录解决 1无用