数据库性能优化涉及到很多方面,在数据库开发时可以通过一些基本的优化技巧提高数据库的性能:
1.原则上为创建的每个表都建立一个主键,主键唯一标识某一行记录,用于强制表的实体完整性。sql server 2005 database engine 将通过为主键列创建唯一索引来强制数据的唯一性。查询中使用主键时,此索引还可用来对数据进行快速访问。(注意:如果你建立了主键,默认情况下它就是聚集索引)
2.为每一个外键列建立一个索引,如果确认它是唯一的,就建立唯一索引。当在查询中组合相关表中的数据时,经常在联接条件中使用外键列,索引使 sql server 2005 数据库引擎 可以在外键表中快速查找相关数据。
3.暂时不要为其他列建立索引
4.当在tsql中引用对象时,建议使用对象的架构名称限定。(使用
dbo.sysdatabases代替sysdatabases)未指定架构可能会导致混淆和意义不明确,还有一个重要原因,当很多连接同时运行同一个存储过程时,如果未指定架构名称,这些连接可能会因为要获取编译锁(compile lock)而互相阻塞。
5.使用set nocount on在每个存储过程的开头set nocount off在结尾。当 set nocount 为 on 时,将不给客户端发送存储过程中的每个语句的 done_in_proc 信息。
1.原则上为创建的每个表都建立一个主键,主键唯一标识某一行记录,用于强制表的实体完整性。sql server 2005 database engine 将通过为主键列创建唯一索引来强制数据的唯一性。查询中使用主键时,此索引还可用来对数据进行快速访问。(注意:如果你建立了主键,默认情况下它就是聚集索引)
2.为每一个外键列建立一个索引,如果确认它是唯一的,就建立唯一索引。当在查询中组合相关表中的数据时,经常在联接条件中使用外键列,索引使 sql server 2005 数据库引擎 可以在外键表中快速查找相关数据。
3.暂时不要为其他列建立索引
4.当在tsql中引用对象时,建议使用对象的架构名称限定。(使用
dbo.sysdatabases代替sysdatabases)未指定架构可能会导致混淆和意义不明确,还有一个重要原因,当很多连接同时运行同一个存储过程时,如果未指定架构名称,这些连接可能会因为要获取编译锁(compile lock)而互相阻塞。
5.使用set nocount on在每个存储过程的开头set nocount off在结尾。当 set nocount 为 on 时,将不给客户端发送存储过程中的每个语句的 done_in_proc 信息。