1
azh7138m 2016 年 11 月 6 日 via Android COUNT(DISTINCT user_id) 不就很好吗?
|
2
bazingaterry 2016 年 11 月 6 日 via iPhone
单独开一个表记录一下?
|
4
hxsf 2016 年 11 月 6 日 via iPhone
select count 1 group by userid
|
5
cjyang1128 2016 年 11 月 6 日
这种类型的优化一般都是通过反范式,比如题目表里面单独开一个字段记录 accepted 人数和 accepted 提交数,更新的时候采用 select for update 上行锁进行更新。或者可以用其他的数据库实现这种类似的计数器操作,比如 Redis 或 HBase
|
6
latyas 2016 年 11 月 6 日
@t123yh
现在的问题是,要多快?现有的速度是否无法接受? 如果还没达到量级建议暂时不要考虑优化问题,良结构的方案都会相对来说慢,但是如果不需要,还是不要放弃良好的结构比较好。 @cjyang1128 计数器场景的话建议不要使用 select for update ,我们在这上面被坑出 shi 来了,不如直接用 REDIS 的 INC 操作。 |
8
latyas 2016 年 11 月 6 日
几万条都是小数据,没必要优化
|
12
azh7138m 2016 年 11 月 7 日 via Android
@ZiLong 做张 ac 表,加个缓存。
但这会遇到其他的问题,比如 rejudge 时,要重新统计下,还是要用 submit 表去算,其实也没啥,数据量真的很难多到数据库出现瓶颈 |
15
cjyang1128 2016 年 11 月 7 日
@latyas 是不是导致了死锁。。
|
16
latyas 2016 年 11 月 15 日
@cjyang1128 是的,如果 select for update 语句放在一个比较大的事务里,经常会发生死锁 /
|