SQL Server数据库中存储引擎深入探讨
2007-05-15 09:26:39 来源:WEB开发网SQL Server 7.0有两种类型的盘区:统一的和混合的。统一的盘区属于一个单独的对象:盘区中的所有页都只能由属主对象使用。
SQL Server 7.0中引入的混合区域对于小型的应用程序工作得很好。在SQL Server,表的空间增加是一次一个盘区。在SQL 7中,对于微型表而言,这会导致巨大的过载,因为现在页的大小是8KB。一个混合盘区允许将一个单独页分配给一个小型表或索引。只有当分配给表或索引的页数超过了8页时,它才会开始分配统一区域。混合盘区最多由8个对象共享。一个新表或索引是从混合盘区中分配页的。当一个表或索引增长到8页时,它就转向统一盘区。
破损页检测
破损页检测保证了数据库的一致性。在SQL Server 7.0中,页的大小是8KB,而Windows NT Server 是在512字节的段中执行I/O操作的。这一差异使得写一个页的一部分成为可能,这可能在电源故障发生时,或是在第一个512字节的段正在写和8KB的I/O已经完成这两个时间之间会发生。
如果写入了第一个512字节的段,可能会出现页已经被更新,而实际上此时还没有更新。(页的时间戳在页头中,页头是页的最开始96个字节。)有几种方法来处理这一问题。你可以使用电池支持的高速缓存的I/O设备,这些设备保证要么有要么全无的I/O。如果你有这些系统之一,破损页检测就没有必要了。
通过创建一个位的掩码,SQL Server可以测试到不完整的I/O操作。在位掩码中,从页中每个段中抽取一位。每次写一个页时,该位就从它以前的状态翻转(就好象它是在磁盘上一样),并且实际状态保存在页头中。如果读了一个页且有一位处于错误的状态,这就意味着I/O操作没有完成,有一个破损页。与作校验相比,这种机制更加划算。
你可以打开或关闭破损页检测,因为当位翻转时,会在页头上做上标记。如果打开或关闭破损页检测,那么就能够观察到页中已经翻转了的状态,并且在下次读取的时候能够修改过来。
SQL Server 7.0使用一系列操作系统文件来创建一个数据库,每一个数据库都有一个独立的文件。在同一个文件中再也不可能存在多个数据库。这一简化非常重要的优点,文件可以增大或收缩,并简化了空间管理。
- ››sql server自动生成批量执行SQL脚本的批处理
- ››sql server 2008亿万数据性能优化
- ››SQL Server 2008清空数据库日志方法
- ››sqlserver安装和简单的使用
- ››SQL Sever 2008 R2 数据库管理
- ››SQL SERVER无法安装成功,sqlstp.log文件提示[未发...
- ››Sql Server中通过父记录查找出所有关联的子记录
- ››SqlServer触发器、存储过程和函数
- ››SQL Server 中的事务(含义,属性,管理)
- ››Sqlite数据库插入和读取图片数据
- ››Sql server 2005拒绝了对对象 'xx表' (数...
- ››Sql server 2005拒绝了对对象 'xx表' (数...
赞助商链接