V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
caoyufei
V2EX  ›  问与答

mysql like 匹配问题

  •  
  •   caoyufei · Nov 8, 2017 · 1855 views
    This topic created in 3103 days ago, the information mentioned may be changed or developed.

    现在有个需求是 从已有的 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 replies    2017-11-08 17:07:53 +08:00
    msg7086
        1
    msg7086  
       Nov 8, 2017
    如果是比较固定的数据和比较固定的标签的话,用 1 就行了。让 MySQL 做查询缓存来提速。

    其他实现的话,就是把表结构规范化,提升范式水平。
    kanshan
        2
    kanshan  
       Nov 8, 2017
    如果你的 5 个标签存在某个表中的话
    ```sql
    SELECT * FROM tabel a INNER JOIN tag b WHERE LOCATE(b.tag,a.field) > 0
    ```
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1052 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 22:46 · PVG 06:46 · LAX 15:46 · JFK 18:46
    ♥ Do have faith in what you're doing.