- 浏览: 244927 次
文章分类
- 全部博客 (395)
- Tech (0)
- [随笔分类]心情 (95)
- [随笔分类]技术 (112)
- [随笔分类]管理心得 (13)
- [随笔分类]Code SOP (5)
- [随笔分类]望图知意 (11)
- [网站分类]1.首页原创精华.NET区(包含架构设计、设计模式)(对首页文章的要求:原创、高质量、经过认真思考并精心写作) (8)
- [随笔分类]重构代码 (1)
- [随笔分类]童童 (2)
- Program (1)
- [随笔分类]看你知道不知道 (1)
- [网站分类]4.其他技术区 (31)
- [网站分类]3.非技术区(技术之外的文章,但不要涉及任何政治内容) (21)
- [网站分类]9.求职招聘区(个人求职、企业招聘) (0)
- [随笔分类]昨日关注 (15)
- [网站分类]6.读书区(技术书籍阅读心得、书籍推荐) (3)
- [随笔分类]一步一个脚印 (2)
- [网站分类]网站管理区(网站管理方面的疑问、建议、意见, 寻求管理员帮助) (1)
- [网站分类]2..NET新手区(用于发表不合适发表在首页的.NET技术文章,包括小经验、小技巧) (3)
最新评论
今天用户抱怨,为什么数据库中条目的计数越来越大,而且清空数据库后重新计数,还是变大?
其实这是我在设计的时候懒惰造成的,产品使用的是SQLServer数据库,数据库的字段ID是标识列,是自增的,当时没有考虑ID变大的情况,所以就任由着字段编号无限的变大,也没有注意,当用户抱怨的时候,也没太当回事,因为程序没有什么错误呀.
其实这是一个不好的用户体验,而我们完全可以解决,其实在删除数据或全部删除数据的时候,增加一个校验,如果数据库中记录数目为0,那么就重新设置标识列的计数,也就很简单了,其实我们真的不应该忽视任何细节,就是一个简单的删除记录/清空表,其实都大有学问的.
在SQLServer中的解决方法如下:
DBCC CHECKIDENT
检查指定表的当前标识值,如有必要,还对标识值进行更正。
举例:
强制表中的当前标识值为 1。
另外一条需要注意的语句是
TRUNCATE TABLE
删除表中的所有行,而不记录单个行删除操作。
DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用 DELETE。如果要删除表定义及其数据,请使用 DROP TABLE 语句。
若要删除表中的所有行,则 TRUNCATE TABLE 语句是一种快速、无日志记录的方法。该语句总是比不带条件的 DELETE 语句要快,因为 DELETE 语句要记录对每行的删除操作,而 TRUNCATE TABLE 语句只记录整个数据页的释放。TRUNCATE TABLE 语句立即释放由该表的数据和索引占用的所有空间。所有索引的分发页也将释放。
与 DELETE 语句相同,使用 TRUNCATE TABLE 清空的表的定义,同其索引和其它相关的对象一起仍保留在数据库中。必须使用 DROP TABLE 语句才能除去表的定义。
呵呵,有些时候看帮助就是不认真,往往几句话,能够对程序性能和效果有很大的改变.
其实这是我在设计的时候懒惰造成的,产品使用的是SQLServer数据库,数据库的字段ID是标识列,是自增的,当时没有考虑ID变大的情况,所以就任由着字段编号无限的变大,也没有注意,当用户抱怨的时候,也没太当回事,因为程序没有什么错误呀.
其实这是一个不好的用户体验,而我们完全可以解决,其实在删除数据或全部删除数据的时候,增加一个校验,如果数据库中记录数目为0,那么就重新设置标识列的计数,也就很简单了,其实我们真的不应该忽视任何细节,就是一个简单的删除记录/清空表,其实都大有学问的.
在SQLServer中的解决方法如下:
DBCC CHECKIDENT
检查指定表的当前标识值,如有必要,还对标识值进行更正。
举例:
DBCC CHECKIDENT (TableName, RESEED, 1)
强制表中的当前标识值为 1。
另外一条需要注意的语句是
TRUNCATE TABLE
删除表中的所有行,而不记录单个行删除操作。
DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用 DELETE。如果要删除表定义及其数据,请使用 DROP TABLE 语句。
若要删除表中的所有行,则 TRUNCATE TABLE 语句是一种快速、无日志记录的方法。该语句总是比不带条件的 DELETE 语句要快,因为 DELETE 语句要记录对每行的删除操作,而 TRUNCATE TABLE 语句只记录整个数据页的释放。TRUNCATE TABLE 语句立即释放由该表的数据和索引占用的所有空间。所有索引的分发页也将释放。
与 DELETE 语句相同,使用 TRUNCATE TABLE 清空的表的定义,同其索引和其它相关的对象一起仍保留在数据库中。必须使用 DROP TABLE 语句才能除去表的定义。
呵呵,有些时候看帮助就是不认真,往往几句话,能够对程序性能和效果有很大的改变.
发表评论
-
打包应该注意MDAC的安装次序
2005-11-14 16:06 928MDAC得打包通常都是很讨厌得,一直没有太好的办法。以前得解决 ... -
不要忽视细节,由调用一个SqlServer系统存储过程想到的
2005-11-22 13:21 594今天在调用SqlServer中的系统存储过程sp_droplo ... -
CMD命令也要用好
2005-11-30 13:30 963以前一些程序需要执行 ... -
一步一个脚印-产品升级随笔(1)-vision
2005-12-18 08:17 639产品的维护和升级总是困扰着我,犯过很多的错误,吃过很多的亏,如 ... -
一步一个脚印-产品升级随笔(4)-波浪
2005-12-30 11:10 660产品的升级不是一次就可以完成的,需求会像洪水一样永远都不会停止 ... -
国民党的800万军队不是一天消灭的
2006-01-09 15:58 589这几天又去了一趟京城,刚刚回到家里,特别的疲惫,昨天美美的在家 ... -
还不如扔掉
2006-01-12 12:42 548周六、周日打算搬回学校的单身宿舍了,把租的房子退掉,但是屋子里 ... -
看你知道不知道之-全局对象
2006-02-10 12:49 623这几天在整理类库,想通过VB6来提供全局函数,将公司常用的函数 ... -
看你知道不知道之-制作数据字典
2006-02-10 17:49 967这部分内容和VB6的关系不大,但是确是困扰我的一个问题。 这几 ... -
看你知道不知道之-为进程内部件设置基地址
2006-02-13 11:17 671在用Project Analyzer 进行 ... -
看你知道不知道之-Call转义序列
2006-02-14 13:00 599今天在整理代码的时候,需要修改一个函数,使这个函数可以通过AD ... -
看你知道不知道之-使用SET NOCOUNT优化存储过程
2006-02-15 14:51 737每次我们在使用查询分析器调试SQL语句的时候,通常会看到一些信 ... -
看你知道不知道之-你注意Where子句的次序了吗?
2006-02-16 08:12 575这个系列越来越多的是和SQL语句相关的问题了,因为这段时间工作 ... -
看你知道不知道之-用好sp_depends
2006-02-21 12:25 1100前几天检查一个兄弟写的存储过程,我想知道这个存储过程到底涉及到 ... -
今天20,明天21
2006-03-06 15:58 537这几天一直封闭,昨天刚刚放出来,感觉十分的疲惫。在封闭的过程中 ... -
重构代码-随笔(1)
2006-03-09 10:32 553原始代码: If txt ... -
干这行最重要的是要坐住板凳
2006-03-12 20:40 700我们周五的时候刚刚辞退的一个试用期员工,给我在QQ留言,内容大 ... -
看你知道不知道之-别惹我Msgbox的Title
2006-03-13 19:40 579在VB6中,MsgBox是比较讨厌的,我在整理代码的时候,通常 ... -
Windows Server 2003 R2 修复Windows Server 2003
2006-03-19 13:05 1159最近特别喜欢去反波上听平客的段子,有一些也下载到本地了,但是我 ... -
靠左侧通行
2006-03-23 08:15 708从小老师和父母就告诉我,一定要靠人行横道的右侧通行,我也是 ...
相关推荐
文档开发必备,你开发过程中遇到的问题和一下小毛病都可以来这里解决。
解决服务器的小毛病 为大家提供一点方便 同时赚取积分
如果你为了一些电脑的问题而发愁!如果有些问题你无法解决!如果你的电脑有小毛病但是你又不知道如何解决! 那就别再犹豫了。我把我说收集的精华编辑成了文档。想要的可以下载下去看看! 我这里就不一一解释了!!
深入研究Servlet线程安全性问题,在开发中,可能我们有时候没有注意到程序中的一些细节,看看吧,可能你也有这些细节上的小毛病。
使用css容易犯的一下小毛病,在这里总结了一下,希望对各位有帮助。
添加到注册表后解决右键没有记事本的问题 (没办法用的是盗版系统自然是有些小毛病了)
免了篇幅过大的毛病. 这本教材自1989 年起即在南京大学强化部大学物理学课程中试用,1993 年起又用于南京大学天文系的学生.历次教学的效果良好:它激发了学生对物 理学的兴趣,也培养了思考物理学问题的能力,这从...
有几个小毛病,特别告诉大家一下: 1、软件问题:开机进行面部识别后,Luxand Blink! 并不自动退出,而是驻留系统托盘,占用内存30M左右。并且每次进入登录界面会有小卡的感觉。 2、面部识别的大问题:如果你把你...
网络管理课程设计做的一个SNMP,C++写的,程序没什么问题,不过还是有点小毛病,仅供参考.
二、 安装完成后先不在不要运行,输因为他还有点小毛病,我们需要在下载页面找到“Sikuli X R930 ”连接,把这个zip类型的文件下载下来。 三、 我们将下载的文件sikuli-r930-win32.zip解压,然后得到一个SIKULI-...
做了一个整理归纳,其中包括oracle数据库的数据导入、导出,面对表格文件怎样用命令快速导入oracle数据库,数据库字符集的更改,使用oracle数据库过程中出现的一些小的毛病等问题的解决,对oracle数据库的表空间的...
兜兜浏览器又更新,增加了快捷键功能,增加了隐藏成小图标功能,增加兜兜小闹钟软件,解决了浏览器的一些小毛病和卸载等的逻辑问题。收发信还没解决附件问题,努力中…… 安全性说明: 一样的编译器和安装包制作...
在eclipse中导入了一个很大的项目,然后就觉得eclipce变的好慢,动不动还会挂掉~ 这时候只要在eclipse的安装目录下,打开eclipce.ini文件,把默认的内存大小很改了,就应该能解决问题了。我的电脑内存是2G的,于是...
什么是大型网站,从网站的技术角度考虑这个问题人们很容易犯一个毛病就是认为网站的访问量是衡量的指标,懂点行的人也许会认为是网站在单位时间里的并发量的大小来作为指标,如果按这些标准那么像hao123网站就是了。...
线程应用,TANK大战服务器及其CLIENT源代码,这个是GUI方面的一个程序,有些小毛病,但是运行是没有问题的,现在可以作为一个聊天室用,协议是TCP+UDP,在局域网内使用。
超市为了方便结算都会使用超市收款机,给商家和顾客带来便利的同时也会闹点小毛病,这让超市经营者头疼不已。我们只要了解到收款机故障原因,就很好解决了。
相比以前的51610版本, 主要是安全更新, 没发现什么新功能, 反而多了几个小毛病 (已修复). 日常使用还是建议刷 spoon 的 51610版固件, 很稳定. 如果已经刷了spoon的华硕51610版, 可以直接在 系统管理->固件升级 里...
用VC++ 6.0实现语音的双工通信,基于C/S模式,数据的收发采用AsyncSocket来实现!可惜的是,在Debug下是成功的,但在Realse下还有点小毛病!希望那位解决此问题后给我指点一二!感激中!邮箱:ylwuwei921@126.com
计算机总是出现一些小的大的毛病、难道不想自己动动手解决解决啊?
07-更多MySQL数据库增量恢复大讨论及大总结 08-MySQL增量恢复小结及核心恢复思想 09-课后自学能力作业-务必完成并分享讲解 10-内部学员技术大会分享课表说明 第九部-老男孩MySQL服务日志详细介绍及增量恢复命令实践...