找回密码
 加入怎通
查看: 253|回复: 1

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

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

8 v3 t5 W+ Q: [
4 P. E* [: u) ^2 Y* h3 m$ f& g% F
回复

使用道具 举报

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

使用道具 举报

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

    本版积分规则

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

    GMT+8, 2026-4-1 19:27 , Processed in 0.186794 second(s), 23 queries , Gzip On.

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

    Powered by Discuz! X3.5

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