一个 mysql 查询问题

2014-11-24 17:37:34 +08:00
 hellohacker
某个表中的某个字段存储的数据形式为
demo
10,15,20
------
20,21,23,
------
30,35,40

现在有个字符串如:15,21,35,可以匹配到上面三条记录,因为三条记录中分别含有15 21 35
求sql
2234 次点击
所在节点    问与答
3 条回复
huigeer
2014-11-24 18:42:17 +08:00
mysql 正则
tabris17
2014-11-24 18:53:42 +08:00
多次查询

select * from tab1 where demo like '15,%'
select * from tab1 where demo like '%,15,%'
select * from tab1 where demo like '%,15'
select * from tab1 where demo like '21,%'
select * from tab1 where demo like '%,21,%'
select * from tab1 where demo like '%,21'
select * from tab1 where demo like '35,%'
select * from tab1 where demo like '%,35,%'
select * from tab1 where demo like '%,35'
wdd2007
2014-11-24 18:57:23 +08:00
SELECT * FROM table WHERE FIND_IN_SET(15,demo) OR FIND_IN_SET(21,demo) OR FIND_IN_SET(35,demo);

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/148943

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX