V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
caoyufei
V2EX  ›  问与答

mysql like 匹配问题

  •  
  •   caoyufei · 2017-11-08 14:53:37 +08:00 · 1376 次点击
    这是一个创建于 2556 天前的主题,其中的信息可能已经有所发展或是发生改变。

    现在有个需求是 从已有的 5 个标签 aa, bb,cc,dd,ee 去查询相识的标签 比如 aab bba 这样的要匹配出来

    1:循环 5 次

    for(;;)
    select * from tabel where field like '%tag%'
    

    2:like 多次

    select * from tabel where field like '%tag1%' or like '%tag2%' ...
    

    3 有没有其他实现?

    标签都是中文的

    2 条回复    2017-11-08 17:07:53 +08:00
    msg7086
        1
    msg7086  
       2017-11-08 15:06:42 +08:00
    如果是比较固定的数据和比较固定的标签的话,用 1 就行了。让 MySQL 做查询缓存来提速。

    其他实现的话,就是把表结构规范化,提升范式水平。
    kanshan
        2
    kanshan  
       2017-11-08 17:07:53 +08:00
    如果你的 5 个标签存在某个表中的话
    ```sql
    SELECT * FROM tabel a INNER JOIN tag b WHERE LOCATE(b.tag,a.field) > 0
    ```
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1063 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 19:34 · PVG 03:34 · LAX 11:34 · JFK 14:34
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.