浅谈tempdb在SqlServer系统中的重要作用

 更新时间:2014年08月20日 09:27:21   投稿:hebedich  
tempdb是SQLServer的系统数据库一直都是SQLServer的重要组成部分,用来存储临时对象。tempdb中的任何数据在系统重新启动之后都不会持久存在。因为实际上每次SQLServer启动的时候都会重新创建tempdb。这个特性就说明tempdb不需要恢复。

简介:

       tempdb是SQLServer的系统数据库一直都是SQLServer的重要组成部分,用来存储临时对象。可以简单理解tempdb是SQLServer的速写板。应用程序与数据库都可以使用tempdb作为临时的数据存储区。一个实例的所有用户都共享一个Tempdb。很明显,这样的设计不是很好。当多个应用程序的数据库部署在同一台服务器上的时候,应用程序共享tempdb,如果开发人员不注意对Tempdb的使用就会造成这些数据库相互影响从而影响应用程序。

特性:

1、 tempdb中的任何数据在系统重新启动之后都不会持久存在。因为实际上每次SQLServer启动的时候都会重新创建tempdb。这个特性就说明tempdb不需要恢复。

2、 tempdb始终设置为“simple”的恢复模式,当你尝试修改时都会报错。也就是说已提交事务的事务日志记录在每个检查点后都标记为重用。

3、 tempdb也只能有一个filegroup,不能增加更多文件组。

4、 tempdb被用来存储三种类型的对象:用户对象,内部对象、版本存储区

以上是基础知识。

如果SQL Server对tempdb访问不频繁,

tempdb对数据库不会产生影响;相反如果访问很频繁,loading就会加重,

tempdb的性能就会对整个DB产生重要的影响

.优化tempdb的性能变的很重要的,尤其对于大型数据库。

注:在优化tempdb之前,请先考虑tempdb对SQL Server性能产生多大的影响,评估遇到的问题以及可行性。

1、最小化的使用tempdb

SQL Server中很多的活动都活发生在tempdb中,所以在某种情况可以减少多对tempdb的过度使用,以提高SQL Server的整体性能。

如下有几处用到tempdb的地方:

(1)用户建立的临时表.如果能够避免不用,就尽量避免. 如果使用临时表储存大量的数据且频繁访问,考虑添加index以增加查询效率。

(2)Schedule jobs.如DBCC CHECKDB会占用系统较多的资源,较多的使用tempdb.最好在SQL Server loading比较轻的时候做。

(3)Cursors.游标会严重影响性能应当尽量避免使用。

(4)CTE(Common Table Expression).也会在tempdb中执行。

(5)SORT_INT_TEMPDB.建立index时会有此选项。

(6)Index online rebuild。

(7)临时工作表及中间结果集.如JOIN时产生的。

(8)排序的结果。

(9)AFTER and INSTEAD OF triggers。

不可能避免使用tempdb,如果有tempdb的瓶颈或issue,就该返回来考虑这些问题了。

2、重新分配tempdb的空间大小

在SQL Server重启时会自动建立8MB大小的tempdb,自动增长默认为10%. 对于小型的数据库来说,8MB大小已经足够了.但是对于较大型的数据库来说,8MB远远不能满足SQL Server频繁活动的需要,因此会按照10%的比例增加,比如说需要1GB,则会需要较长的时间,此段时间会严重影响SQL Server的性能. 建议在SQL Server启动时设置tempdb的初始化的大小(如下图片设置为MDF:300MB,LDF:50MB),也可以通过ALTER DATABASE来实现. 这样在SQL Server在重启时tempdb就会有足够多的空间可利用,从而提高效率。

难点在于找到合理的初始化大小,在SQL Server活动频繁且tempdb不在增长时会是一个合适的值,可以设置此时的值为Initial Size;当然还会有更多的考量,此为一例。

3、不要收缩tempdb(如没有必要)

有时候我们会注意到tempdb占用很大的空间,但是可用的空间会比较低时,会想到shrink数据库来释放磁盘空间, 此时要小心了,可能会影响到性能。

4 、分派tempdb的文件和其他数据文件到不用的IO上

tempdb对IO的要求比较高,最好分配到高IO的磁盘上且与其他的数据文件分到不用的磁盘上,以提高读写效率.

tempdb也分成多个文件,一般会根据CPU来分,几个CPU就分几个tempdb的数据文件. 多个tempdb文件可以提高读写效率并且减少IO活动的冲突。

常用的脚本如下:

--查tempdb库的大小

select a.name, sum(size)*8.0/1024/1024 as [GB]

, sum(size)*8.0/1024 as [MB]

from master.dbo.sysdatabases a inner join master.dbo.sysaltfiles b on a.dbid=b.dbid

WHERE a.name='tempdb'

group by a.name

order by 1

后记:

tempdb是SQL Server重要的一部分,今天发现数据的tempdb特别大,所以对tempdb的一些了解和总结,以后还需要进一步学习。

相关文章

  • SQLServer 批量插入数据的两种方法

    SQLServer 批量插入数据的两种方法

    在SQL Server 中插入一条数据使用Insert语句,但是如果想要批量插入一堆数据的话,循环使用Insert不仅效率低,而且会导致SQL一系统性能问题。下面介绍SQL Server支持的两种批量数据插入方法:Bulk和表值参数(Table-Valued Parameters)。
    2009-07-07
  • SQL Server使用T-SQL语句批处理

    SQL Server使用T-SQL语句批处理

    这篇文章介绍了SQL Server使用T-SQL语句进行批处理的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Sql检验数据库中各个表的数据量

    Sql检验数据库中各个表的数据量

    本文主要介绍了Sql检验数据库中各个表的数据量,这样的查询有助于评估每个表的数据量,从而更好地进行数据库性能优化,具有一定的参考价值,感兴趣的可以了解一下
    2023-12-12
  • 异步的SQL数据库封装详解

    异步的SQL数据库封装详解

    一直在寻找一种简单有效的库,它能在简化数据库相关的编程的同时提供一种异步的方法来预防死锁。使用这个库,你可以轻松地连接到任何SQL-Server数据库,执行任何存储过程或 T-SQL 查询,并异步地接收查询结果。这个库采用C#开发,没有其他外部依赖。
    2015-09-09
  • SQL Server中调用C#类中的方法实例(使用.NET程序集)

    SQL Server中调用C#类中的方法实例(使用.NET程序集)

    这篇文章主要介绍了SQL Server中调用C#类中的方法实例(使用.NET程序集),本文实现了在SQL Server中调用C#写的类及方法,需要的朋友可以参考下
    2014-10-10
  • SQL命令大全-中英文对照

    SQL命令大全-中英文对照

    SQL命令大全-中英文对照...
    2007-11-11
  • SQL学习笔记四 聚合函数、排序方法

    SQL学习笔记四 聚合函数、排序方法

    SQL学习笔记四 聚合函数、排序方法,在数据调用中非常实用。
    2011-08-08
  • SQLServer导出数据库字典的详细图文教程

    SQLServer导出数据库字典的详细图文教程

    查询sqlserver的数据库的数据结构,返回数据字典结果,可手动将查询的结果导出成excel等格式保存,下面这篇文章主要给大家介绍了关于SQLServer导出数据库字典的相关资料,需要的朋友可以参考下
    2022-11-11
  • SQL Server格式转换函数Cast、Convert介绍

    SQL Server格式转换函数Cast、Convert介绍

    这篇文章介绍了SQL Server中的格式转换函数Cast、Convert,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • SQLServer:探讨EXEC与sp_executesql的区别详解

    SQLServer:探讨EXEC与sp_executesql的区别详解

    本篇文章是对EXEC与sp_executesql的区别进行了详细的分析介绍,需要的朋友参考下
    2013-06-06

最新评论