高效管理SQL Server的提示、技巧和解决方案
《SQL Server 2012管理高级教程(第2版)》教授读者成功管理SQL Server 2012所需的技能,你将会学到如何处理最困难的管理难题,包括变更管理、安全性、性能调优、监控、备份。你还可以学到如何掌握SQLServer 2012中的新特性,包括客户端连接性的提升、云计算、数据复制以及商业智能。这本由业内领先专家撰写的详尽指南将会帮助你提升效率、可扩展性以及SQL Server的性能,因此你可以在更短的时间内完成更多任务。
◆ 探讨能够提升SQL Server性能的设置和配置项
◆ 展示如何实现在为数据库建立索引时制订的策略
◆ 集群的安装、配置以及测试步骤
◆ SQL Server备份和还原中所能用到的选项,并为较大化利用这些功能提供建议
◆ 涵盖集成SharePoint 2010与SQL Server 2012所需了解的知识
◆ 对SQL Azure进行介绍,使你对这个激动人心的云平台有所准备
第1章 SQL Server 2012体系结构
1.1 SQL Server 2012生态系统
1.2 SQL Server 2012的重要新增功能
1.2.1 生产DBA
1.2.2 开发DBA
1.2.3 商业智能DBA和开发人员
1.3 SQL Server体系结构
1.3.1 数据库文件和事务日志
1.3.2 SQL Native Client
1.3.3 标准系统数据库
1.3.4 架构
1.3.5 同义词
1.3.6 动态管理对象
1.3.7 SQL Server 2012数据类型
1.4 SQL Server版本
1.4.1 版本概览
1.4.2 许可
1.5 小结
第2章 SQL Server 2012安装最佳实践
2.1 规划系统
2.1.1 硬件选择
2.1.2 软件和安装选择
2.2 安装SQL Server
2.2.1 全新安装
2.2.2 并列安装
2.2.3 升级安装
2.2.4 自动安装
2.2.5 手动安装
2.3 安装Analysis Services
2.3.1 多维和数据挖掘模式(UDM模式)
2.3.2 表格模式
2.4 安装PowerPivot for SharePoint
2.5 系统压力测试
2.6 安装后的配置
2.6.1 配置SQL Server设置以实现高性能
2.6.2 tempdb
2.6.3 针对安全配置SQL Server设置
2.6.4 Best Practices Analyzer(BPA)
2.6.5 SQL Server配置管理器
2.6.6 备份
2.7 卸载SQL Server
2.7.1 卸载Reporting Services
2.7.2 卸载Analysis Services
2.7.3 卸载SQL Server数据库引擎
2.8 故障排除失败安装
2.9 小结
第3章 升级到SQL Server 2012的最佳实践
3.1 升级到SQL Server 2012的原因
3.1.1 减少风险--微软的贡献
3.1.2 独立软件厂商和SQL社区的贡献
3.2 升级到SQL Server 2012
3.2.1 本地升级
3.2.2 并列升级
3.2.3 本地升级与并列升级的考虑事项
3.3 升级前的操作步骤和可用工具
3.3.1 升级前的步骤
3.3.2 升级前的工具
3.4 向后兼容性
3.4.1 SQL Server 2012中不支持和未延续的功能
3.4.2 SQL Server 2012弃用的数据库功能
3.4.3 SQL Server 2012中其他影响行为的变化
3.5 SQL Server组件的考虑事项
3.5.1 升级全文目录
3.5.2 升级Reporting Services
3.5.3 升级到64位
3.6 升级后检查
3.7 小结
第4章 数据库引擎管理与故障排除
4.1 配置和管理工具
4.1.1 SQL Server配置管理器
4.1.2 启动参数
4.1.3 启动存储过程
4.1.4 部分包含的数据库
4.2 故障排除工具
4.2.1 专用管理员连接
4.2.2 重建系统数据库
4.3 Management Studio
4.3.1 报表
4.3.2 在Management Studio中配置SQL Server
4.3.3 筛选对象
4.3.4 错误日志
4.3.5 活动监视器
4.4 在T-SQL中监控进程
4.4.1 sp_who和sp_who2
4.4.2 sys.dm_exec_connections
4.4.3 sys.dm_exec_sql_text
4.5 多服务器管理
4.5.1 中央管理服务器和服务器组
4.5.2 SQL Server实用工具
4.6 跟踪标志
4.7 获得技术支持
4.7.1 SQLDumper.exe
4.7.2 SQLDiag.exe
4.8 小结
第5章 自动化SQL Server
5.1 维护计划
5.1.1 维护计划向导
5.1.2 维护计划设计器
5.2 使用SQL Server代理自动化SQL Server
5.2.1 作业
5.2.2 计划
5.2.3 操作员
5.2.4 警报
5.3 SQL Server代理安全性
5.3.1 服务账户
5.3.2 访问SQL Server代理
5.3.3 SQL Server代理的代理
5.4 配置SQL Server代理
5.4.1 常规属性
5.4.2 高级属性
5.4.3 警报系统属性
5.4.4 作业系统属性
5.4.5 连接属性
5.4.6 历史记录属性
5.5 数据库邮件
5.5.1 体系结构
5.5.2 安全性
5.5.3 配置
5.5.4 归档
5.6 多服务器管理
5.6.1 使用标记替换
5.6.2 事件转发
5.6.3 使用WMI
5.6.4 多服务器管理--使用主服务器和目标服务器
5.7 小结
第6章 SQL Server 2012中的Service Broker
6.1 异步消息
6.1.1 SQL Server Service Broker概览
6.1.2 SQL Server Service Broker和其他消息队列的对比
6.2 配置SQL Server Service Broker
6.2.1 启用
6.2.2 消息类型
6.2.3 约定
6.2.4 队列
6.2.5 服务
6.2.6 路由
6.2.7 优先级
6.2.8 会话组
6.3 使用SQL Server Service Broker
6.3.1 发送消息
6.3.2 接收消息
6.3.3 在数据库之间发送消息
6.3.4 在实例间发送消息
6.3.5 外部激活
6.4 小结
第7章 SQL Server中的CLR集成
7.1 CLR简介
7.1.1 作为.NET运行时主机的SQL Server
7.1.2 应用程序域
7.1.3 T-SQL与CLR
7.1.4 启用CLR集成
7.2 创建CLR程序集
7.2.1 不使用Visual Studio的方式
7.2.2 使用Microsoft SQL Server Data Tools
7.3 保护CLR
7.4 性能监控
7.4.1 Windows系统监控器
7.4.2 SQL Profiler
7.4.3 DMV
7.4.4 CLR集成的设计目标
7.5 小结
第8章 保护数据库实例
8.1 身份验证类型
8.1.1 SQL身份验证
8.1.2 Windows身份验证
8.1.3 SQL Server身份验证和Windows
身份验证的对比
8.2 设定安全对象
8.2.1 服务器安全对象
8.2.2 数据库安全对象
8.2.3 权限链
8.2.4 跨数据库所有权链接
8.3 行级别安全
8.4 小结
第9章 变更管理
9.1 创建解决方案和项目
9.1.1 创建连接
9.1.2 创建项目查询
9.2 基于策略的管理
9.2.1 基于策略的管理概述
9.2.2 基于策略的管理的步骤
9.2.3 脚本化基于策略的管理
9.2.4 基于策略的管理的实现方式
9.3 DDL触发器语法
9.3.1 数据库触发器
9.3.2 服务器触发器
9.4 触发器视图
9.5 脚本概述
9.5.1 sqlcmd
9.5.2 PowerShell
9.6 创建变更脚本
9.7 数据层应用程序
9.7.1 SQL Server Data Tools
9.7.2 版本表
9.8 小结
第10章 配置服务器来调整性能
10.1 DBA需要了解的与性能有关的知识
10.1.1 性能调整周期
10.1.2 定义良好性能
10.1.3 关注重点
10.2 开发DBA需要知道的与性能有关的知识
10.2.1 用户
10.2.2 SQL语句
10.2.3 数据使用模式
10.2.4 健壮的架构
10.3 生产DBA需要知道的与性能有关的知识
10.3.1 优化服务器
10.3.2 硬件管理
10.4 CPU
10.4.1 x64
10.4.2 缓存
10.4.3 超线程
10.4.4 多核
10.4.5 系统体系结构
10.5 内存
10.5.1 物理内存
10.5.2 物理地址空间
10.5.3 虚拟内存管理器
10.5.4 页面文件
10.5.5 页面错误
10.6 I/O
10.6.1 网络
10.6.2 磁盘
10.6.3 关于存储的考虑事项
10.6.4 设计存储系统
10.6.5 大型存储系统考虑事项:SAN系统
10.6.6 服务器配置
10.6.7 碎片化
10.7 小结
第11章 优化SQL Server 2012
11.1 应用程序优化
11.1.1 定义工作负载
11.1.2 目标是系统协调
11.2 I/O问题
11.2.1 SQL Server I/O进程模型
11.2.2 数据库文件的位置
11.2.3 tempdb需要考虑的事项
11.3 表和索引分区
11.3.1 分区的原因
11.3.2 创建分区函数
11.3.3 创建文件组
11.3.4 创建分区方案
11.3.5 创建表和索引
11.4 数据压缩
11.4.1 行压缩
11.4.2 页面压缩
11.4.3 估计节省的空间
11.4.4 监控数据压缩
11.4.5 数据压缩需要考虑的事项
11.5 CPU考虑事项
11.5.1 缓存一致性
11.5.2 关联掩码
11.5.3 最大并行度(MAXDOP)
11.5.4 I/O关联掩码
11.6 内存考虑事项和改进
11.6.1 优化SQL Server内存
11.6.2 SQL Server 2012的64位版本
11.6.3 数据本地化
11.6.4 最大服务器内存
11.6.5 索引创建内存选项
11.6.6 每次查询占用的最小内存
11.7 资源调控器
11.7.1 资源调控器的基本组成元素
11.7.2 在SQL Server 2012
Management Studio中使用资源调控器
11.7.3 监控资源调控器
11.8 小结
第12章 监控SQL Server
12.1 监控的目标
12.1.1 确定监控对象
12.1.2 建立基准
12.1.3 比较当前指标和基准
12.2 选择合适的监控工具
12.3 性能监视器
12.3.1 CPU资源计数器
12.3.2 磁盘活动
12.3.3 内存使用率
12.3.4 性能监控工具
12.4 监控事件
12.4.1 默认跟踪
12.4.2 system_health会话
12.4.3 SQL跟踪
12.4.4 事件通知
12.4.5 SQL Server扩展事件
12.5 使用动态管理视图和函数进行监控
12.5.1 SQL Server的运行状态
12.5.2 查看锁定信息
12.5.3 查看阻塞信息
12.5.4 数据库中的索引使用率
12.5.5 数据内没有使用的索引
12.5.6 查看等待内存授予的查询
12.5.7 已连接用户的信息
12.5.8 文件组空闲空间
12.5.9 当前运行的查询的查询计划和查询文本
12.5.10 内存使用率
12.5.11 缓冲池内存使用
12.6 监控日志
12.6.1 监控SQL Server错误日志
12.6.2 监控Windows事件日志
12.7 管理数据仓库
12.7.1 系统数据收集组
12.7.2 查看系统数据收集组收集的数据
12.7.3 创建自己的数据收集组
12.7.4 检查收集的数据
12.8 SQL Server标准报表
12.9 System Center Management Pack
12.10 SQL Server Best Practice Analyzer
12.11 System Center Advisor
12.12 小结
第13章 T-SQL性能调整
13.1 物理查询处理第一部分:编译和重新编译
13.1.1 编译
13.1.2 重新编译
13.1.3 用于重新编译的工具和命令
13.1.4 分析器和Algebrizer
13.1.5 优化
13.2 物理查询处理第二部分:执行
13.2.1 数据库I/O信息
13.2.2 使用查询计划
13.2.3 估计的执行计划
13.2.4 实际执行计划
13.2.5 索引访问方法
13.2.6 碎片化
13.2.7 统计信息
13.2.8 连接算法
13.2.9 数据修改查询计划
13.2.10 针对分区表和索引的查询处理改进
13.2.11 使用SQL跟踪收集查询计划以用于分析
13.3 小结
第14章 创建数据库索引
14.1 SQL Server中与索引相关的主要功能
14.1.1 SQL Server 2012中新增的索引功能
14.1.2 SQL Server 2008 R2、SQL Server 2008和SQL Server 2005中的索引功能
14.2 分区表和分区索引
14.2.1 理解索引
14.2.2 创建索引
14.2.3 使用分区表和分区索引的原因
14.2.4 创建分区表
14.3 索引维护
14.3.1 监控索引碎片
14.3.2 整理索引
14.4 使用索引改进查询性能
14.5 数据库引擎优化顾问
14.6 索引太多
14.7 小结
第15章 复制
15.1 复制概述
15.1.1 复制的组成
15.1.2 复制类型
15.1.3 SQL Server 2012中复制的改进
15.2 复制模型
15.2.1 单个发布者,一个或多个订阅者
15.2.2 多个发布者,单个订阅者
15.2.3 多个发布者同时也是订阅者
15.2.4 更新订阅者
15.2.5 对等
15.3 实现复制
15.3.1 设置快照复制
15.3.2 建立分发数据库
15.3.3 实现快照复制
15.3.4 实现事务和合并复制
15.4 对等复制
15.4.1 建立对等复制
15.4.2 配置对等复制
15.5 生成复制脚本
15.6 监控复制
15.6.1 复制监视器
15.6.2 性能监视器
15.6.3 复制DMV
15.6.4 sp_replcounters
15.7 小结
第16章 SQL Server 2012群集
16.1 群集与组织
16.1.1 群集能做什么
16.1.2 群集不能做什么
16.1.3 选用SQL Server 2012群集的条件
16.1.4 群集以外的其他选择
16.2 群集概述
16.2.1 群集的工作原理
16.2.2 群集选项
16.3 SQL Server群集的升级
16.3.1 不升级
16.3.2 就地升级到SQL Server 2012群集
16.3.3 从头开始重建群集
16.3.4 回退计划
16.3.5 最好的升级选择
16.4 群集的准备工作
16.4.1 基础设施的准备工作
16.4.2 硬件的准备工作
16.5 Windows Server 2008的群集
16.5.1 安装Windows故障转移群集前的准备工作
16.5.2 安装Windows故障转移群集
16.6 群集Microsoft分布式事务处理协调器
16.7 SQL Server 2012的群集
16.7.1 群集SQL Server的步骤
16.7.2 服务包及累计更新的安装
16.7.3 反复测试
16.8 管理和监控群集
16.9 群集的故障排除
16.9.1 如何对Windows故障转移群集进行故障排除
16.9.2 故障的预防工作
16.9.3 故障信息的收集
16.9.4 故障的解决
16.9.5 与Microsoft合作
16.10 小结
第17章 备份与恢复
17.1 故障类型
17.1.1 硬件故障
17.1.2 数据修改故障
17.1.3 软件故障
17.1.4 局部灾难
17.2 制订计划
17.2.1 备份/恢复计划
17.2.2 灾难恢复计划
17.2.3 创建灾难恢复计划
17.2.4 维护计划
17.3 备份和还原概述
17.3.1 备份的工作方式
17.3.2 复制数据库
17.3.3 备份压缩
17.3.4 恢复模式之间的比较
17.3.5 选择一种恢复模式
17.3.6 在恢复模式间切换
17.3.7 备份历史表
17.3.8 备份与还原要求的权限
17.3.9 备份系统数据库
17.3.10 全文备份
17.3.11 验证备份映像
17.3.12 还原的工作方式
17.4 恢复计划
17.4.1 可恢复性需求
17.4.2 数据使用模式
17.4.3 维护时间窗口
17.4.4 其他高可用性解决方案
17.5 开发与执行备份计划
17.5.1 使用SQL Server Management Studio
17.5.2 数据库维护计划
17.5.3 使用T-SQL备份命令
17.6 管理备份
17.7 备份与还原的性能
17.8 执行恢复
17.8.1 还原过程
17.8.2 使用SQL Server Management Studio还原数据库
17.8.3 T-SQL还原命令
17.8.4 还原系统数据库
17.9 归档数据
17.9.1 SQL Server中表的分区
17.9.2 分区视图
17.10 小结
第18章 SQL Server 2012日志传送
18.1 日志传送部署方案
18.1.1 使用日志传送创建热后备服务器
18.1.2 使用日志传送作为灾难恢复解决方案
18.1.3 使用日志传送作为报告数据库解决方案
18.2 日志传送体系结构
18.2.1 主服务器
18.2.2 辅助服务器
18.2.3 监控服务器
18.3 日志传送进程
18.4 系统要求
18.4.1 网络
18.4.2 具有同等容量的服务器
18.4.3 存储
18.4.4 软件
18.5 部署日志传送
18.5.1 初始配置
18.5.2 通过Management Studio部署
18.5.3 通过T-SQL命令来部署
18.6 监控与故障排除
18.6.1 通过Management Studio进行监控
18.6.2 通过存储过程进行监控
18.6.3 故障排除方法
18.7 管理角色变更
18.7.1 同步依赖对象
18.7.2 从主服务器角色切换到辅助服务器
18.7.3 在主角色和辅助角色之间切换
18.7.4 把客户端连接重定向到辅助服务器
18.8 数据库备份计划
18.9 集成日志传送与其他高可用性解决方案
18.9.1 SQL Server 2012数据镜像
18.9.2 Windows故障转移群集
18.9.3 SQL Server 2012复制
18.10 删除日志传送
18.10.1 通过Management Studio删除日志传送
18.10.2 通过T-SQL命令删除日志传送
18.11 日志传送性能
18.12 升级到SQL Server 2012的日志传送
18.12.1 宕机时间最小化方法
18.12.2 宕机方法
18.12.3 部署日志传送方法
18.13 小结
第19章 数据库镜像
19.1 数据库镜像概述
19.2 数据库镜像的运行模式
19.3 数据库镜像示例
19.3.1 准备端点
19.3.2 准备用于镜像的数据库
19.3.3 主服务器与镜像服务器间的首次同步
19.3.4 建立镜像会话
19.3.5 无自动故障转移的高安全性运行模式
19.3.6 采用自动故障转移的高安全性运行模式
19.3.7 高性能运行模式
19.4 SQL Server 2012各发行版本中的数据库镜像
19.5 数据库镜像目录视图
19.5.1 sys.database_mirroring
19.5.2 sys.database_mirroring_witnesses
19.5.3 sys.database_mirroring_endpoints
19.6 数据库镜像角色切换
19.6.1 自动故障转移
19.6.2 手动故障转移
19.6.3 强制故障转移
19.7 数据库可用性方案
19.7.1 主服务器丢失
19.7.2 镜像服务器丢失
19.7.3 见证服务器丢失
19.7.4 镜像服务器和见证服务器丢失
19.8 监控数据库镜像
19.8.1 使用系统监视器进行监控
19.8.2 使用数据库镜像监视器进行监控
19.8.3 设置计数器阈值以及发送警报
19.9 数据库镜像故障排除
19.9.1 创建错误故障排除
19.9.2 运行时错误故障排除
19.9.3 自动页面修复
19.10 为故障转移准备镜像服务器
19.10.1 硬件、软件和服务器配置
19.10.2 计划宕机时间内的数据库可用性
19.10.3 镜像服务器上的SQL作业配置
19.10.4 镜像数据库的TRUSTWORTHY位
19.10.5 重定向客户端到镜像
19.11 为多个数据库创建镜像
19.12 数据库镜像以及其他高可用性解决方案
19.12.1 数据库镜像与群集
19.12.2 数据库镜像与事务复制
19.12.3 数据库镜像与日志传送
19.12.4 数据库镜像与可用性组
19.13 设置镜像事件监听器
19.14 数据库快照
19.15 小结
第20章 Integration Services管理和性能调整
20.1 Integration Services简介
20.1.1 Integration Services的用途
20.1.2 Integration Services的4个主要部分
20.1.3 项目管理和更改控制
20.2 Integration Services服务的管理
20.2.1 Integration Services服务概述
20.2.2 配置
20.2.3 事件日志
20.2.4 监控活动
20.3 包部署模型中Integration Services包的管理
20.3.1 使用Management Studio管理包
20.3.2 部署
20.4 项目部署模型中Integration Services包的管理
20.4.1 配置SSIS目录
20.4.2 部署包
20.4.3 配置包
20.5 执行和调度
20.5.1 在SSDT中运行包
20.5.2 使用SQL Server导入和导出向导运行包
20.5.3 使用DTExec运行包
20.5.4 使用DTExecUI运行包(包部署模型)
20.5.5 使用执行包工具运行包(项目部署模型)
20.5.6 使用SQL Server代理调度执行
20.5.7 使用T-SQL运行包
20.6 对Integration Services应用安全性
20.6.1 Integration Services安全性概述
20.6.2 在包部署模型中保护包
20.6.3 项目部署模型中的数据库Integration Services角色
20.7 小结
第21章 Analysis Services管理和性能调整
21.1 Analysis Services概述
21.1.1 MOLAP的组件
21.1.2 表格模型的组件
21.1.3 Analysis Services体系结构组件
21.2 管理Analysis Services服务器
21.2.1 服务器属性
21.2.2 必需的服务
21.2.3 Analysis Services脚本语言
21.3 管理Analysis Services数据库
21.3.1 部署Analysis Services数据库
21.3.2 处理Analysis Services对象
21.3.3 备份和还原Analysis Services数据库
21.3.4 同步Analysis Services数据库
21.4 Analysis Services性能监控和调整
21.4.1 使用SQL Server Profiler监控Analysis Services事件
21.4.2 为重播创建跟踪
21.4.3 将飞行记录器用于事实后分析
21.5 Analysis Services MOLAP模型存储的管理
21.5.1 存储模式
21.5.2 分区配置
21.5.3 在MOLAP模型中设计聚合
21.6 对Analysis Services应用安全性
21.6.1 服务器角色
21.6.2 数据库角色
21.6.3 数据库角色的权限
21.6.4 在表格模型中对Analysis
Services应用安全性
21.7 小结
第22章 SQL Server Reporting Services管理
22.1 SQL Server Reporting Services配置管理器
22.1.1 服务账户
22.1.2 Web服务URL
22.1.3 Reporting Services数据库
22.1.4 报表管理器URL
22.1.5 电子邮件设置
22.1.6 执行账户
22.1.7 加密密钥
22.1.8 扩展部署
22.2 Reporting Services属性
22.2.1 "常规"属性页
22.2.2 "执行"属性页
22.2.3 "历史记录"属性页
22.2.4 "日志记录"属性页
22.2.5 "安全性"属性页
22.2.6 "高级"属性页
22.3 报表执行日志
22.4 报表生成器
22.5 报表管理器
22.5.1 管理报表管理器
22.5.2 管理报表
22.6 小结
第23章 SQL Server 2012与SharePoint 2010集成
23.1 集成的组成部分
23.1.1 PowerPivot
23.1.2 报表服务
23.1.3 Power View
23.1.4 服务应用程序架构
23.2 数据刷新
23.2.1 在Excel中使用数据连接
23.2.2 PerformancePoint数据刷新
23.2.3 Visio Services数据刷新
23.2.4 PowerPivot数据刷新
23.3 小结
第24章 SQL Azure的管理和配置
24.1 SQL Azure简介
24.2 SQL Azure架构
24.2.1 客户端层
24.2.2 服务层
24.2.3 平台层
24.2.4 基础设施层
24.3 配置SQL Azure
24.3.1 服务器和数据库供应
24.3.2 流量调节与负载均衡
24.3.3 配置SQL Azure防火墙
24.3.4 连接到SQL Azure
24.4 管理SQL Azure
24.4.1 创建登录名和用户
24.4.2 分配访问权限
24.5 使用SQL Azure
24.5.1 使用SQL Azure进行备份
24.5.2 SQL Azure对象资源管理器
24.5.3 SQL Azure中缺失的功能
24.6 小结
第25章 AlwaysOn可用性组
25.1 架构
25.1.1 可用性组副本和角色
25.1.2 可用性模式
25.1.3 所支持的故障转移类型
25.1.4 允许只读访问辅助副本
25.2 可用性组示例
25.2.1 配置新的可用性组
25.2.2 配置已经存在的可用性组
25.2.3 可用性组的故障转移操作
25.2.4 挂起可用性数据库
25.2.5 恢复可用性数据库
25.2.6 客户端应用程序连接
25.3 用于只读辅助副本的活动辅助
25.3.1 只读访问行为
25.3.2 辅助副本的客户端可连接性
25.3.3 性能
25.4 在辅助副本上进行备份
25.5 AlwaysOn组面板
25.6 监测和故障排除
25.7 小结