第Ⅰ部分 概述和体系结构 3
第1章 SQL Server 2000概述 3
1.1 SQL Server 2000中的改进 3
1.2 支持大容量内存 3
1.3 支持Internet 4
1.3.1 SQL Server集群 4
1.3.2 多个实例 5
1.3.3 备份和恢复功能 5
1.3.4 改进的复制功能 5
1.3.5 日志输送 5
1.3.6 改善的索引机制 6
1.3.7 增强的Windows 2000安全性能 6
1.3.8 全文搜索 6
1.4 SQL Server 7.0的改进 6
1.4.1 简化的配置 6
1.4.2 动态空间管理 6
1.4.3 数据存储 7
1.4.4 并行查询处理 7
1.4.5 基于成本的锁定 7
1.4.6 存储例程执行的改进 7
1.4.7 连接的分解与合并 7
1.5 性能分析工具 8
1.6 资源消耗者 8
1.6.1 LazyWriter 8
1.6.2 Checkpoint 9
1.6.3 工作线程 10
1.6.4 日志管理器 10
1.6.5 预读管理器 10
1.7 调整SQL Server的关键考虑因素 11
1.8 调整和优化的必要性 11
1.9 小结 11
第2章 存储引擎 13
2.1 存储引擎简介 13
2.2 存储引擎特性 13
2.3 子系统综述 14
2.4 数据库实现的考虑因素 15
2.5 数据的组织 15
2.6 存储空间分配 16
2.6.1 数据页 16
2.6.2 盘区 17
2.6.3 空间分配 18
2.7 数据库文件 18
2.7.1 主数据文件 18
2.7.2 副数据文件 19
2.7.3 日志文件 19
2.7.4 支持多个数据库文件 20
2.8 系统数据库 20
2.8.1 主数据库 20
2.8.2 tempdb数据库 21
2.8.3 模型数据库 23
2.8.4 msdb数据库 24
2.9 数据库的创建、修改和删除 25
2.9.1 用Transact SQL创建数据库 25
2.9.2 用Enterprise Manager创建数据库 27
2.9.3 修改数据库 28
2.9.4 删除数据库 29
2.10 文件组 29
2.10.1 文件和文件组 29
2.10.2 把系统数据和用户数据分离开 30
2.10.3 文件组的类型 30
2.10.4 表和索引的放置 30
2.10.5 利用文件组改善性能 30
2.10.6 采用文件组时保持系统性能的建议 31
2.10.7 创建和管理文件组 31
2.10.8 指定默认文件组 32
2.10.9 从文件组中删除文件——DBCC SHRINKFILE 33
2.11 数据文件和日志文件的维护 34
2.11.1 sp_helpdb例程 35
2.11.2 sp_helpfile例程 35
2.11.3 sp_helpfilegroup例程 35
2.11.4 与自动增长和缩减有关的性能问题 36
2.12 表的组织 37
2.13 数据类型 38
2.14 索引 40
2.14.1 聚群集化的索引 41
2.14.2 非聚群集化的索引 41
2.14.3 分布统计 41
2.15 管理事务日志 42
2.15.1 事务日志简介 42
2.15.2 数据库恢复 42
2.15.3 事务日志结构 43
2.15.4 事务日志的容量 43
2.15.5 对事务日志进行维护 44
2.16 数据库的锁机制 45
2.16.1 锁的模式 45
2.16.2 数据库的一致性——对不完整页的检测 46
2.17 内存的使用 46
2.17.1 动态内存管理 46
2.17.2 内存的建议配置 47
2.18 处理器的使用 47
2.18.1 线程模型 47
2.18.2 并行查询 48
2.18.3 配置选项 48
2.19 小结 49
第3章 查询处理器 50
3.1 查询处理器简介 50
3.2 查询执行 51
3.2.1 执行规划 51
3.2.2 执行规划的使用 51
3.3 查询优化 52
3.3.1 查询优化的几个阶段 52
3.3.2 表扫描和索引扫描的对比 53
3.3.3 工作表和动态索引 54
3.4 查询优化器的类型 55
3.4.1 基于语法的查询优化器 55
3.4.2 基于成本的查询优化器 55
3.5 统计与查询优化器的关系 55
3.6 SQL Server查询处理器的改进 56
3.7 Internet支持 56
3.7.1 结构 57
3.7.2 数据访问 58
3.8 分块视图——SQL Server 2000服务器集群 59
3.8.1 功能 59
3.8.2 实现 59
3.8.3 性能 59
3.9 数据传输的效率 60
3.9.1 预读扫描 60
3.9.2 预取线索 60
3.9.3 排序改善 60
3.10 查询管理器 60
3.11 查询优化技术 61
3.12 连接技术 62
3.12.1 嵌套循环迭代 62
3.12.2 合并连接算法 62
3.12.3 散列连接算法 63
3.12.4 散列组队 64
3.13 线索 64
3.13.1 索引型 65
3.13.2 查询型 65
3.13.3 连接型 65
3.13.4 锁型 66
3.14 建立索引的策略 66
3.14.1 为视图建立索引 66
3.14.2 索引的交叉 67
3.14.3 索引连接 67
3.15 查询的并行处理 67
3.16 存储过程 68
3.17 多阶段 68
3.18 自动参数 69
3.19 过渡谓词 69
3.20 star查询 69
3.21 数据修改的优化 69
3.22 有关查询的工具 70
3.22.1 Query Analyzer 70
3.22.2 SQL Server Profiler 70
3.22.3 Index Tuning Wizard 71
3.23 小结 71
第Ⅱ部分 性能的考虑因素 75
第4章 硬件因素 75
4.1 简介 75
4.2 常见的硬件瓶颈 76
4.3 磁盘配置 81
4.4 要不要RAID 83
4.5 了解RAID等级 85
4.5.1 RAID 0——磁盘条带 85
4.5.2 RAID 1——镜像 85
4.5.3 RAID 5——带奇偶校验的条带 86
4.5.4 双工 86
4.5.5 RAID 0+1 87
4.6 硬件RAID和软件RAID的对比 87
4.7 磁盘和控制器因素 88
4.8 磁盘I/O 88
4.9 传输率 88
4.10 磁盘传输率 89
4.11 流量计算 89
4.12 决定控制器的容量 90
4.12.1 决定能够使流量最大化的磁盘数 91
4.12.2 决定使传输次数最大的磁盘最大数目 91
4.13 PCI总线带宽 92
4.14 磁带设备 92
4.15 磁盘I/O子系统要求的小结 92
4.16 改善磁盘I/O的建议 93
4.17 硬件越多越好 93
4.18 预读管理器 94
4.19 独立操作 94
4.19.1 把数据文件和日志文件分开 94
4.19.2 把tempdb和其他SQL Server对象分开 95
4.20 SQL Server和Windows NT/2000的磁盘因素 95
4.21 内存因素 96
4.21.1 Intel Extended Server Memory Architecture 96
4.21.2 AWE 97
4.21.3 分页 98
4.21.4 关于内存设置的建议 98
4.22 处理器因素 99
4.23 网络因素 101
4.24 小结 101
第5章 实现高度有效的解决方案 103
5.1 高度有效解决方案介绍 103
5.1.1 群集 103
5.1.2 多实例 104
5.1.3 集群服务器 104
5.1.4 备份和恢复功能 104
5.1.5 日志运送 104
5.1.6 备用服务器 105
5.1.7 SQL Server复制 105
5.1.8 Windows负载平衡服务 105
5.2 群集介绍 105
5.2.1 共享设备模型 106
5.2.2 无共享模型 106
5.2.3 群集的好处 107
5.2.4 群集的不利之处 108
5.3 Microsoft群集服务器实现 108
5.4 群集配置 109
5.4.1 主动/主动 109
5.4.2 主动/被动 110
5.5 故障恢复怎样工作 111
5.6 Microsoft群集服务器上的SQL Server 112
5.7 在群集中运行SQL Server的资源问题 113
5.8 SQL Server多重实例 113
5.8.1 介绍多重实例 113
5.8.2 实现多重实例 114
5.8.3 群集配置中的多实例 115
5.8.4 与多实例通讯 116
5.8.5 性能考虑 116
5.9 集群SQL Server 2000服务器 117
5.9.1 Windows DNA 117
5.9.2 SQL Server集群和Windows DNA 118
5.9.3 介绍分割 118
5.9.4 集群的实现考虑 119
5.9.5 性能考虑 120
5.10 备份和恢复能力 121
5.10.1 影响备份策略的因素 121
5.10.2 复原模型 122
5.10.3 复原间隔 124
5.10.4 部分数据库恢复 124
5.10.5 标记事务 124
5.10.6 SQL Server怎样进行备份和恢复工作 125
5.10.7 备份和恢复操作的性能考虑 125
5.11 日志运送 126
5.11.1 日志运送介绍 127
5.11.2 配置日志运送 127
5.11.3 日志运送监控服务器 128
5.12 备用服务器 128
5.12.1 实现备用服务器 129
5.12.2 提升备用服务器为主服务器 129
5.13 SQL Server复制 129
5.14 小结 131
第6章 应用需要考虑的事项 132
6.1 应用设计考虑因素 132
6.2 正规化 132
6.2.1 正规化过程 133
6.2.2 需求评估 136
6.2.3 理解数据库设计选项 137
6.3 介绍索引 138
6.3.1 怎样访问数据 139
6.3.2 索引策略 140
6.4 索引组件 141
6.5 群集索引 142
6.6 不使用群集索引的表 143
6.7 群集索引的例子 143
6.8 非群集索引 144
6.9 群集索引存在时使用非群集索引的例子 145
6.10 群集索引被删除时非群集索引的例子 146
6.11 索引选择项 147
6.11.1 FILLFACTOR 147
6.11.2 PAD_INDEX 148
6.11.3 排序选项 149
6.12 建立索引 149
6.12.1 使用企业管理器创建索引 150
6.12.2 利用查询分析器建立索引 151
6.13 优化索引建立 151
6.14 复合索引 152
6.15 覆盖索引 153
6.16 索引视图 153
6.16.1 使用索引视图的时间 154
6.16.2 使用索引视图的策略 155
6.16.3 索引视图的建立 155
6.16.4 索引视图的限制 155
6.17 索引选择 157
6.18 理解索引选择性和密度 158
6.18.1 选择性 159
6.18.2 密度 159
6.19 影响查询性能的索引因素 160
6.19.1 统计 160
6.19.2 索引 161
6.19.3 视图 162
6.19.4 碎片 163
6.20 用于管理索引的工具 163
6.20.1 查询分析器和Graphical Showplan 163
6.20.2 SQL Server Profiler和Index Tuning Wizard 163
6.21 管理表、索引和统计的DBCC 164
6.21.1 DBCC SHOWCONTIG 164
6.21.2 DBCC INDEXDEFRAG 168
6.21.3 DBCC SHOW_STATISTICS 169
6.21.4 DBCC UPDATE STATISTICS 170
6.21.5 DBCC CREATE STATISTICS 171
6.21.6 DBCC DBREINDEX 172
6.22 小结 172
第Ⅲ部分 分析解决问题——调节和优化 177
第7章 使用Windows NT/2000工具进行性能调节 177
7.1 监控对象 177
7.2 建立基线 177
7.3 Windows NT/2000性能监控器 178
7.4 介绍性能监控器 178
7.5 性能监控选项 179
7.5.1 系统监控器/图表视图 179
7.5.2 警告视图 181
7.5.3 日志视图 184
7.5.4 报告能力—报告视图 187
7.6 监控每一个关键领域 188
7.7 理解CPU使用 188
7.7.1 改善性能的考虑 189
7.7.2 找出处理器性能问题的动作 190
7.7.3 判断是否是由于其他事情引起CPU瓶颈 190
7.7.4 把进程卸载到不同的服务器 190
7.7.5 增加额外的CPU资源 191
7.7.6 重新配置现有资源 191
7.8 了解磁盘使用 191
7.8.1 物理或者逻辑磁盘对象 192
7.8.2 Windows NT/2000对象——物理/逻辑磁盘 192
7.8.3 改善性能的考虑 193
7.9 理解页故障——内存对象 195
7.10 Windows NT/2000对象——进程 196
7.11 Windows NT/2000对象——线程 197
7.12 Windows NT/2000对象——网络 200
7.13 SQL Server对象 200
7.14 SQL Server默认性能监控工作空间文件 202
7.15 SQL Server对象——访问方法 202
7.16 SQL Server对象——备份设备 203
7.17 SQL Server对象——缓存管理器 204
7.18 SQL Server对象——高速缓存管理器 206
7.19 SQL Server对象——数据库 206
7.20 SQL Server对象——通用统计 208
7.21 SQL Server对象——锁 208
7.22 SQL Server对象——内存管理器 209
7.23 SQL Server对象——复制代理对象 210
7.24 SQL Server对象——复制分布对象 211
7.25 SQL Server对象——复制日志读取对象 211
7.26 SQL Server对象——复制合并对象 212
7.27 SQL Server对象——复制快照对象 212
7.28 SQL Server对象——统计 213
7.29 SQL Server对象——用户设置对象 213
7.30 使用Windows NT/2000控制面板监控性能 214
7.31 虚拟内存 214
7.32 应用响应 216
7.33 服务 217
7.33.1 WINDOWS NT V4服务 217
7.33.2 WINDOWS 2000服务 218
7.34 网络绑定 219
7.35 任务管理器 219
7.35.1 “应用”标签 220
7.35.2 “进程”标签 221
7.35.3 “性能”标签 222
7.36 系统信息/Windows NT诊断 222
7.37 小结 224
第8章 监控和配置SQL Server 225
8.1 介绍 225
8.2 “企业管理器” 225
8.2.1 “一般”标签 226
8.2.2 网络配置 230
8.2.3 SQL Server属性——“内存”标签 230
8.2.4 SQL Server属性——“处理器”标签 232
8.2.5 SQL Server属性——“数据库设置”标签 233
8.2.6 SQL Server属性——“服务器设置”标签 234
8.2.7 SQL Server属性——“连接”标签 234
8.2.8 SQL Server属性——“安全”标签 235
8.3 sp_configure 236
8.4 监控活动 244
8.5 Sp_monitor 244
8.6 查看和修改数据库选项 245
8.6.1 使用DATABASEPROPERTYEX查看数据库配置 245
8.6.2 改变数据库 247
8.6.3 数据库选项的性能考虑 249
8.6.4 Sp_dboption 250
8.7 管理SQL Server的配置 251
8.7.1 Sp_spaceused 251
8.7.2 sp_helpdb 252
8.8 监控用户活动 254
8.8.1 Sp_who 254
8.8.2 Sp_lock 255
8.8.3 锁模式定义 256
8.8.4 查看死锁 257
8.8.5 DBCC INPUTBUFFER 259
8.8.6 当前活动 259
8.9 监控和管理数据库完整性 261
8.9.1 DBCC CHECKDB 261
8.9.2 DBCC CHECKALLOC 263
8.9.3 DBCC CHECKCATALOG 264
8.9.4 DBCC CHECKFILEGROUP 265
8.9.5 DBCC CHECKTABLE 266
8.9.6 DBCC CLEANTABLE 267
8.9.7 DBCC UPDATEUSAGE 267
8.9.8 DBCC SQLPERF/PERFMON 267
8.9.9 DBCC SQLPERF(IOSTATS) 268
8.9.10 DBCC SQLPERF(LRUSTATS) 269
8.9.11 DBCC SQLPERF(NETSTATS) 270
8.9.12 DBCC SQLPERF(RASTATS) 271
8.9.13 DBCC SQLPERF(THREADS) 272
8.9.14 DBCC SQLPERF(LOGSPACE) 272
8.10 小结 273
第9章 自动化SQL Server任务 274
9.1 自动化SQL Server监控 274
9.2 数据库维护计划 274
9.2.1 建立一个数据库维护计划 275
9.2.2 更改和管理数据库维护计划 282
9.3 作业 287
9.3.1 查看作业状态 288
9.3.2 修改或者创建一个作业 289
9.3.3 步骤 290
9.3.4 日程 290
9.3.5 通知 291
9.4 警告 292
9.4.1 介绍警告 292
9.4.2 理解警告组件 292
9.5 建立警告 295
9.5.1 进行事件警告定义 295
9.5.2 定义警告响应 296
9.6 小结 298
第10章 SQL Server描述器 299
10.1 Server描述器简介 299
10.2 监测事件 300
10.3 事件类别 300
10.3.1 游标 300
10.3.2 数据库 302
10.3.3 出错和警告 302
10.3.4 锁 305
10.3.5 对象 306
10.3.6 性能 307
10.3.7 性能考虑 308
10.3.8 扫描 309
10.3.9 性能考虑 310
10.4 安全审核 310
10.4.1 服务器 313
10.4.2 对话 314
10.4.3 对话的性能考虑 315
10.4.4 存储过程 315
10.4.5 存储的性能考虑 316
10.4.6 事务 317
10.4.7 事务的性能考虑 317
10.4.8 TSQL 317
10.4.9 TSQL的性能考虑 318
10.4.10 用户可配置的 319
10.4.11 默认事件类 319
10.5 数据列 319
10.5.1 默认数据列 320
10.5.2 数据列分组 321
10.6 过滤器 321
10.7 一般追踪信息 322
10.8 示例追踪 324
10.9 创建一个追踪模板 325
10.10 创建追踪去捕获SQL Server的工作量 326
10.11 读追踪文件 329
10.12 重放 330
10.12.1 重放的几个必须条件——事件类 330
10.12.2 重放的几个必须条件——数据列 330
10.12.3 在不同系统上重放一个记录文件 331
10.12.4 重放选项 331
10.12.5 重放的注意事项 332
10.12.6 记录的执行步骤 333
10.13 小结 333
第11章 SQL Server查询分析器 334
11.1 查询分析器简介 334
11.2 执行SQL语句和命令 334
11.3 对象浏览器 335
11.4 按颜色编码更易使用 336
11.5 查看统计、CPU时间和执行概况 337
11.5.1 SET STATISTICS IO 337
11.5.2 SET STATISTICS TIME 340
11.5.3 SET STATISTICS PROFILE 340
11.6 执行索引分析 342
11.7 从查询分析器建立跟踪文件 343
11.8 在SQL Server Profiler中分析数据 344
11.9 ShowPlan和Graphical ShowPlan 344
11.10 用Graphical ShowPlan执行查询 344
11.11 了解Graphical ShowPlan 345
11.12 性能因素 346
11.12.1 连接策略和顺序 347
11.12.2 书签查阅 347
11.12.3 聚群集化索引扫描 347
11.12.4 {AND|OR|AND NOT|OR NOT}存在嵌套迭代 347
11.12.5 索引搜索 347
11.12.6 索引扫描 347
11.12.7 标量聚集 348
11.12.8 排序 348
11.12.9 表扫描 348
11.12.10 (在工作表中)的查询类型是Select 348
11.12.11 更新模式是{直接|延迟} 348
11.12.12 使用GETSORTED表扫描 348
11.12.13 使用动态索引 348
11.12.14 向量聚集 349
11.13 WITH CHECK OPTION 349
11.13.1 工作表n 349
11.13.2 为DISTINCT创建的工作表 349
11.13.3 为ORDER BY创建的工作表 349
11.13.4 为重新格式化创建的工作表 349
11.14 解释节点信息 349
11.15 读取红色标志 352
11.16 创建丢失的统计信息 352
11.17 管理统计信息 353
11.18 管理索引 354
11.19 重新执行查询 354
11.20 对成功的调整分析进行校验 355
11.21 小结 355
第12章 索引调节向导 356
12.1 介绍索引调节向导 356
12.2 使用索引调节向导 357
12.2.1 选择服务器和数据库 357
12.2.2 确定工作任务 358
12.2.3 高级选项 359
12.3 选择需要调节的表 360
12.4 索引调节推荐 361
12.5 索引调节向导推荐方案分析 361
12.5.1 索引使用报告(推荐配置) 361
12.5.2 索引使用报告(当前配置) 362
12.5.3 查询——索引关系报告(推荐配置) 363
12.5.4 查询——索引关系报告(当前配置) 364
12.5.5 视图——表关系报告 364
12.5.6 表分析报告 365
12.5.7 查询开销报告 366
12.5.8 工作分析报告 367
12.5.9 调节总结报告 368
12.6 实施推荐 368
12.7 对脚本文件的评价 369
12.8 建议 372
12.8.1 备份数据库 373
12.8.2 定义和建立一个有代表性的工作任务 373
12.8.3 在非高峰时间内利用索引调节向导分析工作任务 373
12.8.4 执行索引调节向导 373
12.8.5 利用索引调节向导进行重新分析,并解决提出的新的建议 373
12.8.6 备份数据库,重建有代表性的工作任务,并且重新分析工作任务 373
12.9 小结 374
附录A 资源 375
附录B CD的内容 376