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