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

关于#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日

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)