问个 sql 查询语句,部分内容匹配 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
s2555
V2EX    程序员

问个 sql 查询语句,部分内容匹配

  •  
  •   s2555 2014-12-16 10:48:39 +08:00 4320 次点击
    这是一个创建于 4020 天前的主题,其中的信息可能已经有所发展或是发生改变。
    假设我字段内容是 ids=1,2,3,4,我要查询的字符串是 5,2,3,6,他们只有2,3相同,这么查询出来?
    我能想到的只有 ids like '5' or ids like '2' ids like '3' ids like '6' ,有没有更好的办法?
    15 条回复    2014-12-16 17:45:55 +08:00
    mhycy
        1
    mhycy  
       2014-12-16 11:18:47 +08:00
    字符串已知的话用IN
    ids IN ("5","2","3","6")
    Cynic222
        2
    Cynic222  
       2014-12-16 11:22:27 +08:00
    你这样用"like"等于用"="
    l1905
        3
    l1905  
       2014-12-16 13:05:12 +08:00
    ids 字符串前后都加逗号, ids='1,2,3,4' => ids=',1,2,3,4,'
    查询语句: ids like '%,5,%' or ids like '%,2,%' or ids like '%,3,%' or ids like '%,6,%'
    s2555
        4
    s2555  
    OP
       2014-12-16 13:51:55 +08:00
    @mhycy 这样行吗?我只用过当ids值是一个的情况,像现在 1,2,3,4的没有用过。

    @l1905 跟我想的一样啊,当然你这个是最恰当的。
    konakona
        5
    konakona  
       2014-12-16 13:55:12 +08:00
    比如你有一笔数据
    $ids = '1,2,3,7,8,65,32,12,32,55'
    你可以执行:
    select * from tablename where id in ('{$ids}');

    //select * from tablename where id in('1,2,3,7,8,65,32,12,32,55');
    s2555
        6
    s2555  
    OP
       2014-12-16 14:02:18 +08:00
    可能我表达还不清楚,是这样的:
    表结构
    id : 1
    value:1,2,3,4
    要用值=5,2,3,4 去把这个数据查询出来
    难道select * from 表 where value in(5,2,3,4) 这样吗?
    mhycy
        7
    mhycy  
       2014-12-16 14:03:29 +08:00
    @s2555 还以为你那个ids是一个列,原来列的值就是1,2,3啊..这么建表合适么..
    s2555
        8
    s2555  
    OP
       2014-12-16 14:30:05 +08:00
    @mhycy 那是数字相当于人的编号,这样设计已经定了好久了,现在这样想办法去查
    123123
        9
    123123  
       2014-12-16 16:17:15 +08:00
    @l1905 你这样任意值排在第一个怎么搜到?
    @s2555 把 LIKE 换成 FIND_IN_SET
    holystrike
        10
    holystrike  
       2014-12-16 16:30:57 +08:00
    把 5,2,3,6 拆成4个条件, 取 or 串在一起
    select * from table where
    find_in_set(5, 字段名) OR
    find_in_set(2, 字段名) OR
    find_in_set(3, 字段名) OR
    find_in_set(6, 字段名)
    holystrike
        11
    holystrike  
       2014-12-16 16:31:50 +08:00
    但是效率很低
    如果可能的话,重新设计表吧
    s2555
        12
    s2555  
    OP
       2014-12-16 16:43:29 +08:00
    @holystrike 这样的话用 like 就可以啦,看来只能这样的了。谢谢大家
    holystrike
        13
    holystrike  
       2014-12-16 16:58:32 +08:00
    @s2555 like 不行吧,逗号怎么办?
    l1905
        14
    l1905  
       2014-12-16 17:06:25 +08:00
    @123123 ids的值格式只能为',xxx,yyy,' or ',xxxx,' 值收尾必须是','
    123123
        15
    123123  
       2014-12-16 17:45:55 +08:00
    @l1905 这不能由你来规定啊…
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1373 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 23ms UTC 16:55 PVG 00:55 LAX 08:55 JFK 11:55
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86