一、写在前面 - 想说爱你不容易
为了升级数据库至sql server 2008 r2,拿了一台现有的pc做测试,数据库从正式库restore(3个数据库大小夸张地达到100g+),而机器内存只有可怜的4g,不仅要承担db server角色,同时也要作为web server,可想而知这台机器的命运是及其惨烈的,只要ms sql server一启动,内存使用率立马飙升至99%。没办法,只能升内存,两根8g共16g的内存换上,结果还是一样,内存瞬间被秒杀(cpu利用率在0%徘徊)。由于是pc机,内存插槽共俩,网站空间,目前市面上最大的单根内存为16g(价格1k+),就算买回来估计内存还是不够(卧槽,pc机伤不起啊),看样子别无它法 -- 删数据!!!
删除数据 - 说的容易, 不就是delete吗?靠,如果真这么干,我xxx估计能“知道上海凌晨4点的样子”(kb,香港服务器,sorry,谁让我是xxx的programmer,哥在这方面绝对比你牛x),而且估计会暴库(磁盘空间不足,产生的日志文件太大了)。
二、沙场点兵 - 众里寻他千百度
为了更好地阐述我所遇到的困难和问题,有必要做一些必要的测试和说明,同时这也是对如何解决问题的一种探究。因为毕竟这个问题的根本是如何来更好更快的操作数据,说到底就是delete、update、insert、truncate、drop等的优化操作组合,服务器空间,我们的目的就是找出最优最快最好的方法。为了便于测试,准备了一张测试表employee
. (,(50) null,(50) null,);
