1
yxwzaxns Jun 14, 2019 via iPhone
把 userID 的自增值设成你的系统预计服务的用户数量的值,比如 10000 能服务 10 万的用户
|
2
hoythan Jun 14, 2019
。。。匹配 ,6,
|
3
niucility Jun 14, 2019 via Android
find in set
|
4
echoway Jun 14, 2019
select * from table where ','+user_ids+',' like '%, 用户 id, %'
SELECT * FROM table WHERE instr(','+用户 ID+',' , ','+user_ids+',' ) > 0 |
5
aa65535 Jun 14, 2019 FIND_IN_SET()
|
6
Chemist Jun 14, 2019
就这么爱反范式吗。
|
7
msg7086 Jun 14, 2019
可以把表结构转换成更人性化的结构,比如更高范式的结构。
|
8
silentstorm Jun 14, 2019
这表结构设计的简直让人无话可说,而且查询速度估计也快不了。
|
10
IMFFA OP |
11
XuanFei990 Jun 14, 2019
楼主的头像,以前一直拿来当做桌面来着。。
只知道叫夏娜,,☺☺ |
12
gaius Jun 14, 2019
你是用 Set 存的话,就转成对象 contains 不就行了
|
13
opengps Jun 14, 2019
这种建议用外键存储,真要这么用的话修正下楼主的语句:
select * from table where user_ids like '%,id,%' or user_idslike 'id,%' or user_idslike '%,id' 注意要查询的 id 前后加逗号,另外就是,针对开头结尾需要兼容下 |
14
IMFFA OP @XuanFei990
就是夏娜,出自动漫“灼眼的夏娜” |
15
XuanFei990 Jun 14, 2019
@IMFFA 没看过 ,,只是知道名字,仅此而已☺☺
|
16
IMFFA OP |
17
GGGG430 Jun 14, 2019 via iPhone
将这种多个数字存储改成二进制形式,如要存 3,6 则改成 2∧3+2∧6 = 72,最后该字段实际存储的是 64,查阅的时候只需要在 sql 中 select 64&2∧x 即可,简单方便,缺点就是整形数字有上限
|