C_Sharp 板


LINE

这个问题比较像是如何设计。 系统会陆续收到很多笔资料(一天约两千万笔),我想判断这些资料是否有重复。 通常只需要和当天资料比较,也就是说今天资料不需要和两天前的比。 原先我是使用 dictionary储存,收到资料就 add 进 dictionary, 再使用 containskey 方法来做为重复判断。 目前问题出在当系统运作几天後,这个dictionary内的资料量会变得很大 而不需要被比较的资料仍旧存在(如上面所说,要判断重复仅须和资料的+-1天相比) 我想到用 remove(dictionary.keys.first)方式,但是新进的资料就会被放在 first 一旦下一次 remove时就会删到较新的资料 ex: dic.add("1",1); dic.add("2",2); dic.add("3",3); dic.remove(dic.keys.first); dic.add("4",4); 印出结果.. 4,4 2,2 3,3 下一次 remove 4,4就会被删除了 我有想到用sortedDictionary,但是他的速度慢很多,一个是 O(log n),一个是O(1) 想请问有没有更好的方式或建议? -- Mars-玛尔斯群英传,为一种多人的地下城文字网路游戏(MUD), 以西方魔法奇幻风格为背景,让玩家扮演各种职业进行冒险、解谜。 IP:218.161.35.207 8888 讨论板: PTT mud_mars Eplis @ Mars --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 118.163.17.139
1F:→ m339606:两千万....先进资料库如何? 03/18 13:39
2F:→ m339606:资料量大的话在程式码中处理会非常非常非常消耗资源 03/18 13:47
3F:→ eplis:如果说都先进资料库确实没有这个问题,只是每一笔都进资料库 03/18 15:35
4F:→ eplis:去比对是否有重复,会不会制造大量I/O,反而比较慢? 03/18 15:35
5F:→ eplis:这方面我比较没经验.. 03/18 15:35
6F:→ emn178:改用MemoryCache ? 03/18 18:23
7F:→ m339606:进资料库好处是可以分散资源(资料库独立),後续处理容易 03/18 19:00
8F:→ m339606:至於大量IO的问题要看实际运作,可以Cache後定时进资料库 03/18 19:01
9F:→ m339606:从文内判断的话资料会无限制的不断进来 03/18 19:02
10F:→ m339606:1天两千万,10天呢?100天呢?到时候比对会是一个大灾难 03/18 19:02
11F:→ m339606:如果每天清空重新处理的话倒也还好,考虑+-1天比对的话... 03/18 19:03
12F:推 YahooTaiwan:我觉得进资料库会造成更大的灾难欸 两千万笔... 03/18 20:29
13F:推 YahooTaiwan:你有试过OrderedDictionary吗 03/18 20:45
14F:→ ssccg:+-1天比对,不能每天清掉-2天的资料吗 03/18 21:03
很抱歉我补充一下,因为资料只会比对+-1天,所以旧的资料是可以清除的 我有想过一个方法,但是应该不是很好 在资料量进来少的时候,做foreach,判断资料时间 < -1天,就remove ※ 编辑: eplis 来自: 124.218.24.252 (03/18 21:24)
15F:推 g66932007:还没看过table里有两千万笔的资料..... 03/18 21:33
16F:推 YahooTaiwan:请问你remove的条件只有"时间 > 一天"吗 03/18 22:13
是的,有用的资料就是"当下时间"到"当下时间的前一天",其他都已经没用了
17F:→ m339606:两千万笔资料进不进资料库都会有大问题,好处是可以分散 03/18 22:26
18F:→ m339606:不进资料库就需要谨慎考虑资料安全性,例如出错当机 03/18 22:27
19F:→ m339606:存在记忆体给你一个方向就是三个Dictionary 03/18 22:34
20F:→ m339606:A、B、C 每天固定时间从A复制到B、B复制到C,一天分配一个 03/18 22:36
21F:→ m339606:让一天的资料固定占用一个Dictionary,+-一天比对就解决了 03/18 22:37
22F:→ m339606:天啊三个就6千万...权衡一下要用哪种吧,混合也是种方法 03/18 22:41
※ 编辑: eplis 来自: 124.218.24.252 (03/19 00:22)







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:iOS站内搜寻

TOP