sql学习笔记 镜像图解.docx

上传人:b****8 文档编号:29731483 上传时间:2023-07-26 格式:DOCX 页数:18 大小:169.20KB
下载 相关 举报
sql学习笔记 镜像图解.docx_第1页
第1页 / 共18页
sql学习笔记 镜像图解.docx_第2页
第2页 / 共18页
sql学习笔记 镜像图解.docx_第3页
第3页 / 共18页
sql学习笔记 镜像图解.docx_第4页
第4页 / 共18页
sql学习笔记 镜像图解.docx_第5页
第5页 / 共18页
点击查看更多>>
下载资源
资源描述

sql学习笔记 镜像图解.docx

《sql学习笔记 镜像图解.docx》由会员分享,可在线阅读,更多相关《sql学习笔记 镜像图解.docx(18页珍藏版)》请在冰豆网上搜索。

sql学习笔记 镜像图解.docx

sql学习笔记镜像图解

MSSQL学习记录

DBCC

Transact-SQL编程语言提供DBCC语句作为Microsoft®SQLServer™2000的数据库控制台命令。

这些语句对数据库的物理和逻辑一致性进行检查。

许多DBCC语句能够对检测到的问题进行修复。

数据库控制台命令语句被分为以下类别。

语句分类执行

维护语句对数据库、索引或文件组进行维护的任务。

杂项语句诸如启用行级锁定或从内存中删除动态链接库(DLL)等杂项任务。

状态语句状态检查。

验证语句对数据库、表、索引、目录、文件组、系统表或数据库页的分配进行的验证操作。

SQLServer2000的DBCC语句使用输入参数和返回值。

所有DBCC语句参数都可以接受Unicode和DBCS字面值。

使用DBCC结果集输出

许多DBCC命令可以产生表格格式的输出(使用WITHTABLERESULTS选项)。

该信息可装载到表中以便将来使用。

以下显示一个示例脚本:

--Createthetabletoaccepttheresults

CREATETABLE#tracestatus(

TraceFlagINT,

StatusINT

--Executethecommand,puttingtheresultsinthetable

INSERTINTO#tracestatus

EXEC('DBCCTRACESTATUS(-1)WITHNO_INFOMSGS')

--Displaytheresults

SELECT*

FROM#tracestatus

GO

维护语句

DBCCDBREINDEX--重建指定数据库中表的一个或多个索引。

DBCCDBREPAIR--除去损坏的数据库。

DBCCINDEXDEFRAG--整理指定的表或视图的聚集索引和辅助索引碎片。

DBCCSHRINKDATABASE--收缩指定数据库中的数据文件大小。

DBCCSHRINKFILE--收缩相关数据库的指定数据文件或日志文件大小。

DBCCUPDATEUSAGE--报告和更正sysindexes表的不正确内容,该内容可能会导致通过sp_spaceused系统存储过程产生不正确的空间使用报表。

杂项语句

DBCCdllname(FREE)

DBCCHELP

DBCCPINTABLE

DBCCROWLOCK

DBCCTRACEOFF

DBCCTRACEON

DBCCUNPINTABLE

状态语句

DBCCPINTABLE

DBCCOPENTRAN

DBCCOUTPUTBUFFER

DBCCPROCCACHE

DBCCSHOWCONTIG

DBCCSHOW_STATISTICS

DBCCSQLPERF

DBCCTRACESTATUS

DBCCUSEROPTIONS

验证语句

DBCCCHECKALLOC

DBCCCHECKCATALOG

DBCCCHECKCONSTRAINTS

DBCCCHECKDB

DBCCCHECKFILEGROUP

DBCCCHECKIDENT

DBCCCHECKTABLE

DBCCNEWALLOC

------------------------------------以下部分为转帖-----------------------------------------------

DBCC是SQLServer提供的一组控制台命令,功能很强大,掌握一些必要的语句,对操作数据库有不少帮助,所以决定整理一下,发现已有不少类似的整理,减少了不少工作,归类如下:

一、DBCC帮助类命令

*DBCCHELP('?

')

查询所有的DBCC命令

*DBCCHELP('checktable')

查询指定的DBCC命令的语法说明

*DBCCUSEROPTIONS

返回当前连接的活动(设置)的SET选项

二、DBCC检查验证类命令

*DBCCCHECKALLOG('数据库名称')

检查指定数据库的磁盘空间分配结构的一致性

*DBCCCHECKCATALOG('数据库名称')

检查指定数据库的系统表内和系统表间的一致性

*DBCCCHECKCONSTAINTS('tablename')

检查指定表上的指定约束或所有约束的完整性

*DBCCCHECKDB

检查数据库中的所有对象的分配和结构完整性

*DBCCCHECKFILEGROUP

检查指定文件组中所有表在当前数据库中的分配和结构完整性

*DBCCCHECKTABLE

检查指定表或索引视图的数据、索引及test、ntest和image页的完整性

*DBCCCHECKIDENT

检查指定的当前标识值

*DBCCSQLPERF(UMSSTATS)undocumentedinBOL

可以用来检查是否CPU使用达到瓶颈

最关键的一个参考数据numrunnable,表明当前有多少个线程再等待运行

如果大于等于2,考虑CPU达到瓶颈

三、DBCC维护类命令

*DBCCCLEANTABLE('db_name','table_name')

回收Altertabledropcolumn语句删除可变长度列或text

*DBCCDBREINDEX

重建指定数据库的一个或多个索引

*DBCCINDEXDEFRAG

对表或视图上的索引和非聚集索引进行碎片整理

*DBCCPINTABLE(db_id,object_id)

将表数据驻留在内存中

查看哪些表驻留在内存的方法是:

selectobjectproperty(object_id('tablename'),'tableispinned')

*DBCCUNPINTABLE(db_id,object_id)

撤消驻留在内存中的表

*DBCCSHRINKDATABASE(db_id,int)

收缩指定数据库的数据文件和日志文件大小

*DBCCSHRINKFILE(file_name,int)

收缩相关数据库的指定数据文件和日志文件大小

四、DBCC性能调节命令

*DBCCdllname(FREE)

sp_helpextendedproc查看加载的扩展PROC

在内存中卸载指定的扩展过程动态链接库(dll)

*DBCCDROPCLEANBUFFERS

从缓冲池中删除所有缓冲区

*DBCCFREEPROCCACHE

从过程缓冲区删除所有元素

*DBCCINPUTBUFFER

显示从客户机发送到服务器的最后一个语句

*DBCCOPENTRAN(db_name)

查询某个数据库执行时间最久的事务,由哪个程序拥有

*DBCCSHOW_STATISTICS

显示指定表上的指定目标的当前分布统计信息

*DBCCSHOWCONTIG

显示指定表的数据和索引的碎片信息

*DBCCSQLPERF

(logspace)查看各个DB的日志情况

(iostats)查看IO情况

(threads)查看线程消耗情况

返回多种有用的统计信息

*DBCCCACHESTATS

显示SQLServer2000内存的统计信息

*DBCCCURSORSTATS

显示SQLServer2000游标的统计信息

*DBCCMEMORYSTATS

显示SQLServer2000内存是如何细分的

*DBCCSQLMGRSTATS

显示缓冲中先读和预读准备的SQL语句

五、DBCC未公开的命令

*DBCCERRLOG

初始化SQLServer2000的错误日志文件

*DBCCFLUSHPROCINDB(db_id)

清除SQLServer2000服务器内存中的某个数据库的存储过程缓存内容

*DBCCBUFFER(db_name,object_name,int(缓冲区个数))

显示缓冲区的头部信息和页面信息

*DBCCDBINFO(db_name)

显示数据库的结构信息

*DBCCDBTABLE

显示管理数据的表(数据字典)信息

*DBCCIND(db_name,table_name,index_id)

查看某个索引使用的页面信息

*DBCCREBUILDLOG

重建SQLServer2000事务日志文件

*DBCCLOG(db_name,3)(-1--4)

查看某个数据库使用的事物日志信息

*DBCCPAGE

查看某个数据库数据页面信息

*DBCCPROCBUF

显示过程缓冲池中的缓冲区头和存储过程头

*DBCCPRTIPAGE

查看某个索引页面的每行指向的页面号

*DBCCPSS(user,spid,1)

显示当前连接到SQLServer2000服务器的进程信息

*DBCCRESOURCE

显示服务器当前使用的资源情况

*DBCCTAB(db_id,object_id)

显示数据页面的结构

六、DBCC跟踪标记

跟踪标记用于临时设置服务器的特定特征或关闭特定行为,常用于诊断性能问题或调试存储过程或复杂的计算机系统

*DBCCTRACEON(3604)

打开跟踪标记

*DBCCTRACEOFF

关闭跟踪标记

*DBCCTRACESTATS

查看跟踪标记状态

七、使用DBCC结果集输出

  许多DBCC命令可以产生表格格式的输出(使用WITHTABLERESULTS选项)。

该信息可装载到表中以便将来使用。

以下显示一个示例脚本:

  

  CREATETABLEDBCCResult(

  DBCCFlagINT,

  ResultINT

  )

  INSERTINTODBCCResult

  EXEC('DBCCTRACESTATUS(-1)WITHNO_INFOMSGS')

  SELECT*

  FROMDBCCResult

八、官方使用DBCC的建议

1、在系统使用率较低时运行CHECKDB。

2、请确保未同时执行其它磁盘I/O操作,例如磁盘备份。

3、将tempdb放到单独的磁盘系统或快速磁盘子系统中。

4、允许tempdb在驱动器上有足够的扩展空间。

使用带有ESTIMATEONLY的DBCC

估计tempdb将需要多少空间。

5、避免运行占用大量CPU的查询或批处理作业。

6、在DBCC命令运行时,减少活动事务。

7、使用NO_INFOMSGS选项显著减少处理和tempdb的使用。

8、考虑使用带有PHYSICAL_ONLY选项的DBCCCHECKDB来检查页和记录首部

的物理结构。

当硬件导致的错误被置疑时,这个操作将执行快速检查。

在发布,订阅复制时要用服务器实名时可以这样:

select*fromsysservers(可以找到原来服务器的名称)

execsp_dropserver'jmsql9'(删除原来的服务器名)

execsp_addserver'jmSQL9',LOCAL(改为新的服务器名)

ALTERDATABASE[jm]SETSINGLE_USER(改为单用户模式)

DBCCCHECKDB("databasename",REPAIR_REBUILD)WITHTABLOCK(修复数据库)

DBCCCHECKTABLE("tablename",repair_rebuild)withtablock(修复表)

DBCCDBREINDEX('t_icitem','')修复此表所有的索引。

ALTERDATABASE[jm]SETMULTI_USER(改为多用户模式)

REPAIR_ALLOW_DATA_LOSS:

执行由REPAIR_REBUILD完成的所有修复,包括对行和页进行分配和取消分配以改正分配错误、结构行或页的错误,以及删除已损坏的文本对象。

这些修复可能会导致一些数据丢失。

修复操作可以在用户事务下完成以允许用户回滚所做的更改。

如果回滚修复,则数据库仍会含有错误,应该从备份进行恢复。

如果由于所提供修复等级的缘故遗漏某个错误的修复,则将遗漏任何取决于该修复的修复。

修复完成后,备份数据库。

REPAIR_FAST进行小的、不耗时的修复操作,如修复非聚集索引中的附加键。

这些修复可以很快完成,并且不会有丢失数据的危险。

REPAIR_REBUILD执行由REPAIR_FAST完成的所有修复,包括需要较长时间的修复(如重建索引),执行这些修复时不会有丢失数据的危险。

dbccshrinkdatabase(jm)压缩数据库

 

USEmaster

GO

execsp_dboption'数据库名字','singleuser','true'-设置单用户模式

Go

Use数据库名字

---重新整理所有索引

execsp_msforeachtable'DBCCDBREINDEX(''?

'')'

dbcccheckdb('数据库名字',REPAIR_ALLOW_DATA_LOSS)--修复数据库

DBCCCheckDB('数据库名字',Repair_Rebuild)--修复索引

sp_dboption'数据库名字','singleuser','false'--取消单用户模式

GO

sp_spaceused查看数据库空间的大小

Usemaster

Go

Execsp_dboptinon"test",'singleuser','true'

重建索引

Execsp_msforeachtable'dbccdbreindex("?

")'针对全库

DBCCDBREINDEX(‘表名’,'',80)针对一个表

整理索引碎片

DBCCINDEXDEFRAG(表名,索引名)

 

一.实战SQLServer2005数据库镜像

SQLServer2005是微软5年来具有里程碑性质的企业级数据库产品。

在高可用技术、额外的备份和恢复功能,以及复制增强上的投资使企业能够构建和部署高可用的应用系统。

SQLServer2005在高可用上的创新有:

数据镜像,故障转移集群,数据库快照和增强的联机操作,这有助于最小化宕机时间和确保企业的关键系统可用。

下面我们将介绍数据库镜像技术。

一、数据库镜像

SQLServer2005可通过数据库镜像来支持热备功能。

数据库镜像允许事务日志以连续的方式从主服务器传递到备份服务器上。

当主服务器出现故障时,见证服务器几秒钟内即可检测到主服务器发生了故障,并能立即让备份服务器接受数据库连接。

数据库镜像工作在标准服务器硬件下,不需要特定的存储或控制器。

图1显示了数据库镜像的基本配置。

图1:

数据库镜像的基本配置

二、与传统的集群技术比较

故障转移集群是一个高可用解决方案,它使用MicrosoftClusteringServices创建容错虚拟服务器,一旦数据库服务器宕机,便可提供快速故障转移。

在SQLServer2005中,SQLServer分析服务,通知服务,与SQLServer复制现在都已支持故障转移集群。

集群节点的最大数量也增加到8个,SQLServer故障转移集群现已是一个完整的容错服务器解决方案。

从表1中我们可以看出数据库镜像的优点是故障切换时间短,对服务器要求低,无需存储盘柜,所以服务器之间的距离没有要求,甚至可以把服务器一台放在北京,另一台放在上海。

缺点是客户端需要支持ADO.NET2.0或SQLNativeClient,老的应用程序需要升级,需要见证服务器才能实现自动故障转移。

表1数据库镜像与集群的比较

高可用特性

数据库镜像

故障转移集群

故障转移方式

自动、手动

自动、手动

对吞吐量的影响

极小

没有影响

零工作丢失

Yes

Yes

提供冗余数据

Yes

No

故障转移切换时间

小于10秒

30秒以上,视数据量大小

硬件要求

标准服务器

通过集群验证要求的服务器

存储要求

共享盘柜

服务器距离要求

100米

客户端要求

支持ADO.NET和

SQLNativeClient

无,虚拟IP

三、部署数据库镜像

安装好3台WindowsServer2003企业版服务器,先加入到域中,名字为NODE,NODE和NODE,然后依次安装SQLServer2005DeveloperEdition、DeveloperEdition、和SQLExpress。

SQLServer2005对数据库镜像提供支持的版本见表2。

表2数据库镜像与SQLServer2005版本

数据库镜像技术

EnterpriseEdition

DeveloperEdition

StandardEdition

WorkgroupEdition

SQLExpress(免费)

Partner

Witness

在每台服务器上均使用SQLServer外围应用配置器,开放允许通过TCP/IP和NAME访问数据库,这是ServerSQL2005增强安全性的措施之一。

如图2

图2

1.在NODE1上创建一个数据库,名字为testdb_01,数据库的恢复模式必须使用完整模式。

createdatabasetestdb_01

GO

2.完整备份testdb_01数据库。

BACKUPDATABASEtestdb_01

TODISK='C:

\testdb_01.bak'

WITHFORMAT

GO

3.将备份文件拷贝到NODE2的C盘,恢复备份,数据库名必须和NODE1一致,本例为testdb_01,而且必须使用参数NORECOVERY。

RESTOREDATABASEtestdb_01

FROMDISK='C:

\testdb_01.bak'

WITHNORECOVERY

GO

4.在NODE1上运行SQLServerManagementStudio——鼠标右键testdb_01数据库——在属性里单击镜像选择页。

如图3

图3

单击配置安全性——弹出配置数据库安全向导界面,下一步——包括见证服务器,下一步——在以下服务器上保存安全性配置,下一步——主体服务器实例:

NODE1,端口和端点名称默认,下一步。

如图4。

图4

镜像服务器实例:

NODE2,端口和端点名称默认,下一步——见证服务器实例:

NODE3,端口和端点名称默认,下一步——服务账户,下一步——完成。

选择带自动故障转移功能的同步,单击开始镜像。

稍候,镜像成功,在这里可以手动故障转移,测试数据库镜像。

如图5。

图5

四、客户端连接

我在WindowsXPSP2.NETFramework2.0系统上测试了SybasePowerbuilder10.2Build8100开发工具,ADO.NET2.0使用下面的字符串可以连接到数据库,并随故障转移自动切换数据库,访问不受任何影响。

//ProfileSQLServer2005

SQLCA.DBMS="ADO.Net"

SQLCA.LogPass=<*********>

SQLCA.LogId="sa"

SQLCA.AutoCommit=False

SQLCA.DBParm="Namespace='System.Data.SqlClient',DataSource=';FailoverPartner=;InitialCatalog=testdb_01',Database='testdb_01'"

2.实战快照(举例)

我们先来为数据库Northwind创建一个数据库快照,命名为NORTHWIND_DBSS1200,并让此数据库快照的文件存储在C:

\NORTHWIND_DATA_1200.SS文件中

CREATEDATABASENORTHWIND_DBSS1200ON

(NAME=NORTHWIND,FILENAME=

'C:

\NORTHWIND_DATA_1200.SS')

ASSNAPSHOTOFNORTHWIND;

GO

--可以看到这个数据库快照文件的属性,如下:

可以看到现在Sizeondisk为128K

USENORTHWIND

GO

--现在Northwind数据库进行更新操作

UPDATEDBO.CUSTOMERS

SETCOMPANYNAME='NEWEGG.COM'

--可以看到现在Sizeondisk为384K

--看一下Northwind数据库中被更新的列中存储的内容是已经被更新过的

SELECTDISTINCTCOMPANYNAMEFROMNORTHWIND.DBO.CUSTOMERS

--看一下NORTHWIND_DBSS1200数据库中被更新的列中存储的内容还是被更新以前的内容

SELECTDISTINCTCOMPANYNAMEFROMNORTHWIND_DBSS1200.DBO.CUSTOMERS

--IFANERRORDAMAGESADATABASE,YOUMAYCHOOSETOREVERTTHEDATABASETOADATABASESNAPSHOTTHATPREDATESTHEERROR.REVERTINGOVERWRITESTHEORIGINALSOURCEDATABASEWITHTHEREVERTEDDATABASE.

RESTOREDATABASENORTHWINDFROM

DATABASE_SNAPSHOT='NORTHWIND_DBSS1200'

GO

--确认

SELECTDISTINCTCOMPANYNAMEFROMNORTHWIND.DBO.CUSTOMERS

--删除数据库快照

DROPDATABASENORTHWIND_DBSS1200

从数据库快照中恢复数据库到快照创建的时刻

非必需的服务

Alter,ClipBook,ComputerBrowser,Messenger,NetworkDateExchange(DDE),TaskScheduler

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试认证 > 交规考试

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1