qq_38440972 2022-08-20 01:39 采纳率: 100%
浏览 37
已结题

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

有一张表mytable,其中有一列叫name,假设有name属性分别为"ashiqwer","dfwmn","fghes"的三条记录,如何写sql语句,当前端传入"hw"时只能查询到第一条记录?
注意前端传入的字符串是任意的,要使用mybatis去数据库中查找

  • 写回答

3条回答 默认 最新

  • 爱吃苦瓜的猿 2022-08-20 07:48
    关注

    你这个需求应该是要做模糊匹配。
    我理解查询的关键字一般是在前端输入的。
    你在接受到前端输入后,把输入拆分成单个字符,在拼sql的时候每个字符中间都插入模糊匹配符号%。
    譬如前端搜索框输入hw,拆分成单字符的模糊匹配串就成了%h%w%。
    最终执行的sql样例如下:

    select * from mytable where name like '%h%w%;
    

    当你数据量较大(单表超过10W了)时,就需要把name字段加上全文索引,这样效率更高,有需要可以搜索mysql全文索引相关内容。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 8月28日
  • 已采纳回答 8月20日
  • 修改了问题 8月20日
  • 创建了问题 8月20日