找回密码
 加入怎通
查看: 270|回复: 3

[站长八卦] 优化数据库前要注意的几个问题

[复制链接]
2486831241 发表于 2013-12-09 15:29:47 | 显示全部楼层 |阅读模式
在优化你的数据库时,你可能没有用到这些细节的优点。以下是10个关于你的数据库性能的问题,需要你问问自己……5 I; _2 S+ o7 ^/ e8 B9 t9 D: r
  1. 假设你的数据库不需要存储特殊字符的能力,尤其是Unicode标准中规定的那些字符,你有没有在系统中把nchar类型替换成char之类的各种适用的字段类型?0 O% |# G# s- s/ I" N
  2. 你是不是在用smalldatetime类型,而不是datetime?如果你不清楚这两种类型有什么区别,这是一个简单介绍:smalldatetime类型可以存储1900年1月1日至2079年6月6日的日期,而datetime类型把这一范88idea.net围扩展到了1753年1月1日至9999年12月31日。你需要这么大的范围吗?
$ K4 B8 z2 L9 ~! T. e  3. 你是不是例行公事地使用bit类型来代替smallint类型?如果是这样,你知道其中的代价吗?这对你的程序可能并没有影响,但smallint类型可以建立索引,bit类型不行。1 f( H: L+ l6 S, @+ d
  4. SQL Server 2000在bit类型字段中允许空值,而且是默认的。有人希望这样,也有人不希望这样。7 y( x1 g  _6 ]1 W, [$ n& l
  5. 你如何处理字段中的空值?默认方式是允许空值,但更好的办法是禁止空值,允许零长度的字符串。
# n" S/ E1 h4 |  6. 你想过表中能容纳的最多行数吗?你比较过这个数值和数据页的大小8060字节吗?8 z& y3 G' m! v- X. s3 F
  7. 你有没有好好利用标准字段?(去看看菜单里的工具->选项->标准字段)9 h/ u5 j# K$ r- o
  8. 你的表中有没有一个时间戳字段?如果没有的话,你知道什么时候这种字段会有用处吗?( `. F% y" U- Y
  9. 你的表都有区块索引吗?你知道一个表什么时候应该有区块索引,什么时候一文不值吗?
8 t  [/ t- p7 h) n& z- d  10. 你在命名存储过程时有没有用sp_前缀?你有没有意识88yulechen.com到这样做给性能带来了什么影响?
* d" A6 @; P; r7 I1 J' e' x  要避免这些常见的开发问题,一个很好的办法是使用SSW的SQL Auditor,它能审核的事情远远不止我所列出的10条。SQL Auditor的价格很合理,最好的一点是你可以下载测试版,试用20次之后再付费。SSW的试用策略吸引了我,可能因为我经常下载一些限制14天使用的试用软件,之后忘记运行它,直到试用期过去。+ Y5 ^& Z! }' Q9 y

, F/ Z' p7 i& u0 p0 G* V/ ?% b# l5 W- q2 ?
回复

使用道具 举报

≮_龍/kuk域_≯ 发表于 2026-01-29 11:08:08 | 显示全部楼层
刚好遇到类似问题,看完这个帖子心里有底了
回复 支持 反对

使用道具 举报

lsdkiqweo 发表于 2026-05-21 09:59:12 | 显示全部楼层
内容很干货,没有多余的废话,值得反复看
回复 支持 反对

使用道具 举报

花花 发表于 2026-06-21 14:10:53 | 显示全部楼层
这个思路很新颖,打开了新世界的大门,谢谢分享
回复 支持 反对

使用道具 举报

    您需要登录后才可以回帖 登录 | 加入怎通

    本版积分规则

    QQ|手机版|小黑屋|网站地图|真牛社区 ( 苏ICP备2023040716号-2 )

    GMT+8, 2026-6-21 14:14 , Processed in 0.029619 second(s), 26 queries , Gzip On.

    免责声明:本站信息来自互联网,本站不对其内容真实性负责,如有侵权等情况请联系420897364#qq.com(把#换成@)删除。

    Powered by Discuz! X3.5

    快速回复 返回顶部 返回列表