数据库中经常用到的操作和管理数据库的语句总结

 更新时间:2010年06月09日 01:18:22   作者:  
数据库中经常用到的操作和管理数据库的语句,感谢作者的辛勤劳动,很多。


--★★SQL Server 2005及以上版本数据库批量备份存储过程(判断盘符、路径,错误盘符返回,不存在
--路径自动创建)★★★★★★★★★★★★★

USE master
GO
--1.周期性备份数据库代码(保留原来备份的):
--备份文件名为:原数据库名称+'_'+备份日期.bak
IF OBJECT_ID('sp_backupdatabase') IS NOT NULL
DROP PROC sp_backupdatabase
GO
CREATE PROC sp_backupdatabase
@path NVARCHAR(100)--路径
AS
--路径名格式标准化
IF RIGHT(@path,1)<>'\' SET @path=@path+'\'
--获取文件夹信息
DECLARE @t TABLE(id INT IDENTITY,a INT,b INT,c INT)
DECLARE @fpath NVARCHAR(3)
SET @fpath=LEFT(@path,3)
INSERT @t EXEC master..xp_fileexist @fpath
INSERT @t EXEC master..xp_fileexist @path
--如果指定盘符有误不存在,则返回错误提示:
IF EXISTS(SELECT 1 FROM @t WHERE id=1 AND c=0)
BEGIN
RAISERROR(N'输入的盘符不存在,请重新输入!',16,1)
RETURN
END
--如果不存在指定的文件夹,则创建:
ELSE IF EXISTS(SELECT 1 FROM @t WHERE b=0 AND id=2)
BEGIN
DECLARE @mddir NVARCHAR(100)
SET @mddir='md '+@path
EXEC master..xp_cmdshell @mddir
END
--开始备份数据库到指定的目录
DECLARE @s nvarchar(4000)
SELECT @s=ISNULL(@s+';','')
+N'BACKUP database ['+name+'] TO DISK = '''
+@path+name+'_'+CONVERT(NVARCHAR(8),getdate(),112)+N'.bak'''
FROM master..sysdatabases
WHERE name NOT IN('master','tempdb','model','msdb','pubs')--这里筛选不参加备份的数据库
EXEC(@S)
GO
--调用方法:
EXEC sp_backupdatabase 'f:\Backup\tony'
/*
--返回信息:
已为数据库 'mydb',文件 'mydb' (位于文件 1 上)处理了 312 页。
已为数据库 'mydb',文件 'mydb_log' (位于文件 1 上)处理了 1 页。
BACKUP DATABASE 成功处理了 313 页,花费 0.733 秒(3.336 MB/秒)。
已为数据库 'test',文件 'test' (位于文件 1 上)处理了 208 页。
已为数据库 'test',文件 'test_log' (位于文件 1 上)处理了 1 页。
BACKUP DATABASE 成功处理了 209 页,花费 0.413 秒(3.951 MB/秒)。
--备份后的文件列表:
mydb_20100418.bak
test_20100418.bak
*/


--2.周期性备份数据库代码(自动删除原备份文件):
--备份文件名为:原数据库名称.bak
IF OBJECT_ID('sp_backupdatabase') IS NOT NULL
DROP PROC sp_backupdatabase
GO
CREATE PROC sp_backupdatabase
@path NVARCHAR(100)--路径
AS
--路径名格式标准化
IF RIGHT(@path,1)<>'\' SET @path=@path+'\'
--获取文件夹信息
DECLARE @t TABLE(id INT IDENTITY,a INT,b INT,c INT)
DECLARE @fpath NVARCHAR(3)
SET @fpath=LEFT(@path,3)
INSERT @t EXEC master..xp_fileexist @fpath
INSERT @t EXEC master..xp_fileexist @path
--如果指定盘符有误不存在,则返回错误提示:
IF EXISTS(SELECT 1 FROM @t WHERE id=1 AND c=0)
BEGIN
RAISERROR(N'输入的盘符不存在,请重新输入!',16,1)
RETURN
END
--如果不存在指定的文件夹,则创建:
ELSE IF EXISTS(SELECT 1 FROM @t WHERE b=0 AND id=2)
BEGIN
DECLARE @mddir NVARCHAR(100)
SET @mddir='md '+@path
EXEC master..xp_cmdshell @mddir
END
--开始备份数据库到指定的目录
DECLARE @s nvarchar(4000)
SELECT @s=ISNULL(@s+';','')
+N'BACKUP database ['+name+'] TO DISK = '''
+@path+name+N'.bak'' WITH INIT'
FROM master..sysdatabases
WHERE name NOT IN('master','tempdb','model','msdb','pubs')--这里筛选不参加备份的数据库
EXEC(@S)
GO
--调用方法:
EXEC sp_backupdatabase 'f:\Backup\tony2'
/*
--返回信息:
已为数据库 'mydb',文件 'mydb' (位于文件 1 上)处理了 312 页。
已为数据库 'mydb',文件 'mydb_log' (位于文件 1 上)处理了 1 页。
BACKUP DATABASE 成功处理了 313 页,花费 0.599 秒(4.082 MB/秒)。
已为数据库 'test',文件 'test' (位于文件 1 上)处理了 208 页。
已为数据库 'test',文件 'test_log' (位于文件 1 上)处理了 1 页。
BACKUP DATABASE 成功处理了 209 页,花费 0.351 秒(4.651 MB/秒)。
--备份后的文件列表:
mydb.bak
test.bak
*/

--★★DBCC是SQL Server提供的一组控制台命令,功能很强大,掌握一些必要的语句,对操作数据库有不---少帮助,归类如下:

--一、DBCC 帮助类命令

* DBCC HELP('?')
--查询所有的DBCC命令
* DBCC HELP('命令')
--查询指定的DBCC命令的语法说明
* DBCC USEROPTIONS
--返回当前连接的活动(设置)的SET选项

--二、DBCC 检查验证类命令

* DBCC CHECKALLOG ('数据库名称')
--检查指定数据库的磁盘空间分配结构的一致性
* DBCC CHECKCATALOG ('数据库名称')
--检查指定数据库的系统表内和系统表间的一致性
* DBCC CHECKCONSTAINTS ('tablename')
--检查指定表上的指定约束或所有约束的完整性
* DBCC CHECKDB
--检查数据库中的所有对象的分配和结构完整性
* DBCC CHECKFILEGROUP
--检查指定文件组中所有表在当前数据库中的分配和结构完整性
* DBCC CHECKTABLE
--检查指定表或索引视图的数据、索引及test、ntest和image页的完整性
* DBCC CHECKIDENT
--检查指定的当前标识值
* DBCC SQLPERF(UMSSTATS) undocumented in BOL
--可以用来检查是否CPU使用达到瓶颈
--最关键的一个参考数据num runnable,表明当前有多少个线程再等待运行
--如果大于等于2,考虑CPU达到瓶颈

--三、DBCC 维护类命令

* DBCC CLEANTABLE ('db_name','table_name')
--回收Alter table drop column语句删除可变长度列或text
* DBCC DBREINDEX
--重建指定数据库的一个或多个索引
* DBCC INDEXDEFRAG
--对表或视图上的索引和非聚集索引进行碎片整理
* DBCC PINTABLE (db_id,object_id)
--将表数据驻留在内存中
--查看哪些表驻留在内存的方法是:
select objectproperty(object_id('tablename'),'tableispinned')
* DBCC UNPINTABLE (db_id,object_id)
--撤消驻留在内存中的表
* DBCC SHRINKDATABASE(db_id,int)
--收缩指定数据库的数据文件和日志文件大小
* DBCC SHRINKFILE(file_name,int)
--收缩相关数据库的指定数据文件和日志文件大小

--四、DBCC 性能调节命令

* DBCC dllname(FREE)
sp_helpextendedproc 查看加载的扩展PROC
--在内存中卸载指定的扩展过程动态链接库(dll)
* DBCC DROPCLEANBUFFERS
--从缓冲池中删除所有缓冲区
* DBCC FREEPROCCACHE
--从过程缓冲区删除所有元素
* DBCC INPUTBUFFER
--显示从客户机发送到服务器的最后一个语句
* DBCC OPENTRAN (db_name)
--查询某个数据库执行时间最久的事务,由哪个程序拥有
* DBCC SHOW_STATISTICS
--显示指定表上的指定目标的当前分布统计信息
* DBCC SHOWCONTIG
--显示指定表的数据和索引的碎片信息
* DBCC SQLPERF
(logspace) --查看各个DB的日志情况
(iostats) --查看IO情况
(threads) --查看线程消耗情况
--返回多种有用的统计信息
* DBCC CACHESTATS
--显示SQL Server 2000内存的统计信息
* DBCC CURSORSTATS
--显示SQL Server 2000游标的统计信息
* DBCC MEMORYSTATS
--显示SQL Server 2000内存是如何细分的
* DBCC SQLMGRSTATS
--显示缓冲中先读和预读准备的SQL语句

--五、DBCC 未公开的命令

* DBCC ERRLOG
--初始化SQL Server 2000的错误日志文件
* DBCC FLUSHPROCINDB (db_id)
--清除SQL Server 2000服务器内存中的某个数据库的存储过程缓存内容
* DBCC BUFFER (db_name,object_name,int(缓冲区个数))
--显示缓冲区的头部信息和页面信息
* DBCC DBINFO (db_name)
--显示数据库的结构信息
* DBCC DBTABLE
--显示管理数据的表(数据字典)信息
* DBCC IND (db_name,table_name,index_id)
--查看某个索引使用的页面信息
* DBCC REBUILDLOG
--重建SQL Server 2000事务日志文件
* DBCC LOG (db_name,3) (-1--4)
--查看某个数据库使用的事物日志信息
* DBCC PAGE
--查看某个数据库数据页面信息
* DBCC PROCBUF
--显示过程缓冲池中的缓冲区头和存储过程头
* DBCC PRTIPAGE
--查看某个索引页面的每行指向的页面号
* DBCC PSS (user,spid,1)
--显示当前连接到SQL Server 2000服务器的进程信息
* DBCC RESOURCE
--显示服务器当前使用的资源情况
* DBCC TAB (db_id,object_id)
--显示数据页面的结构

六、DBCC跟踪标记

--跟踪标记用于临时设置服务器的特定特征或关闭特定行为,常用于诊断性能问题或调试存储过程或复杂的---计算机系统
* DBCC TRACEON (3604)
--打开跟踪标记
* DBCC TRACEOFF
--关闭跟踪标记
* DBCC TRACESTATS
--查看跟踪标记状态

--七、使用 DBCC 结果集输出

  --许多 DBCC 命令可以产生表格格式的输出(使用 WITH TABLERESULTS 选项)。该信息可装载到
--中以便将来使用。以下显示一个示例脚本:

  
  CREATE TABLE DBCCResult (

  DBCCFlag INT,

  Result INT

  )



  INSERT INTO DBCCResult

  EXEC ('DBCC TRACESTATUS (-1) WITH NO_INFOMSGS')



  SELECT *

  FROM DBCCResult
--八、官方使用DBCC的建议
--1、在系统使用率较低时运行 CHECKDB。
--2、请确保未同时执行其它磁盘 I/O 操作,例如磁盘备份。
--3、将 tempdb 放到单独的磁盘系统或快速磁盘子系统中。
--4、允许 tempdb 在驱动器上有足够的扩展空间。 使用带有 ESTIMATE ONLY 的 DBCC
--估计 tempdb 将需要多少空间。
--5、避免运行占用大量 CPU 的查询或批处理作业。
--6、在 DBCC 命令运行时,减少活动事务。
--7、使用 NO_INFOMSGS 选项显著减少处理和 tempdb 的使用。
--8、考虑使用带有 PHYSICAL_ONLY 选项的 DBCC CHECKDB 来检查页和记录首部
--的物理结构。当硬件导致的错误被置疑时,这个操作将执行快速检查。

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

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




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

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

ALTER DATABASE [jm] SET SINGLE_USER (改为单用户模式)

DBCC CHECKDB("databasename",REPAIR_REBUILD) WITH TABLOCK (修复数据库)

DBCC CHECKTABLE("tablename",repair_rebuild) with tablock (修复表)

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

ALTER DATABASE [jm] SET MULTI_USER (改为多用户模式)

REPAIR_ALLOW_DATA_LOSS:执行由REPAIR_REBUILD 完成的所有修复,包括对行和页进行分配和取消分配以改正分配错误、结构行或页的错误,以及删除已损坏的文本对象。这些修复可能会导致一些数据丢失。修复操作可以在用户事务下完成以允许用户回滚所做的更改。如果回滚修复,则数据库仍会含有错误,应该从备份进行恢复。如果由于所提供修复等级的缘故遗漏某个错误的修复,则将遗漏任何取决于该修复的修复。修复完成后,备份数据库。

REPAIR_FAST 进行小的、不耗时的修复操作,如修复非聚集索引中的附加键。这些修复可以很快完成,并且不会有丢失数据的危险。

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

dbcc shrinkdatabase (jm) 压缩数据库

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/fredrickhu/archive/2009/10/14/4669452.aspx

--★★获得job执行的步骤内容★★★★★★★★★★★★★★★★

select j.name,s.step_id,s.step_name,s.command
from msdb.dbo.sysjobs_view j join msdb.dbo.sysjobsteps s
on j.job_id=s.job_id;

--★★查看死锁和阻塞并杀死它们★★★★★★★★★★★★★★★★

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_lockinfo]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[p_lockinfo]
GO

SET QUOTED_IDENTIFIER ON
GO
SET ANSI_NULLS ON
GO


/*--处理死锁

查看当前进程,或死锁进程,并能自动杀掉死进程

因为是针对死的,所以如果有死锁进程,只能查看死锁进程
当然,你可以通过参数控制,不管有没有死锁,都只查看死锁进程

感谢: caiyunxia,jiangopen 两位提供的参考信息

--邹建 2004.4--*/

/*--调用示例

exec p_lockinfo
--*/
create proc p_lockinfo
@kill_lock_spid bit=1, --是否杀掉死锁的进程,1 杀掉, 0 仅显示
@show_spid_if_nolock bit=1 --如果没有死锁的进程,是否显示正常进程信息,1 显示,0 不显示
as
declare @count int,@s nvarchar(1000),@i int
select id=identity(int,1,1),标志,
进程ID=spid,线程ID=kpid,块进程ID=blocked,数据库ID=dbid,
数据库名=db_name(dbid),用户ID=uid,用户名=loginame,累计CPU时间=cpu,
登陆时间=login_time,打开事务数=open_tran, 进程状态=status,
工作站名=hostname,应用程序名=program_name,工作站进程ID=hostprocess,
域名=nt_domain,网卡地址=net_address
into #t from(
select 标志='死锁的进程',
spid,kpid,a.blocked,dbid,uid,loginame,cpu,login_time,open_tran,
status,hostname,program_name,hostprocess,nt_domain,net_address,
s1=a.spid,s2=0
from master..sysprocesses a join (
select blocked from master..sysprocesses group by blocked
)b on a.spid=b.blocked where a.blocked=0
union all
select '|_牺牲品_>',
spid,kpid,blocked,dbid,uid,loginame,cpu,login_time,open_tran,
status,hostname,program_name,hostprocess,nt_domain,net_address,
s1=blocked,s2=1
from master..sysprocesses a where blocked<>0
)a order by s1,s2

select @count=@@rowcount,@i=1

if @count=0 and @show_spid_if_nolock=1
begin
insert #t
select 标志='正常的进程',
spid,kpid,blocked,dbid,db_name(dbid),uid,loginame,cpu,login_time,
open_tran,status,hostname,program_name,hostprocess,nt_domain,net_address
from master..sysprocesses
set @count=@@rowcount
end

if @count>0
begin
create table #t1(id int identity(1,1),a nvarchar(30),b Int,EventInfo nvarchar(255))
if @kill_lock_spid=1
begin
declare @spid varchar(10),@标志 varchar(10)
while @i<=@count
begin
select @spid=进程ID,@标志=标志 from #t where id=@i
insert #t1 exec('dbcc inputbuffer('+@spid+')')
if @标志='死锁的进程' exec('kill '+@spid)
set @i=@i+1
end
end
else
while @i<=@count
begin
select @s='dbcc inputbuffer('+cast(进程ID as varchar)+')' from #t where id=@i
insert #t1 exec(@s)
set @i=@i+1
end
select a.*,进程的SQL语句=b.EventInfo
from #t a join #t1 b on a.id=b.id
end

GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO

----------版本2: 我在邹建的基础上改写的(KILL 死锁时间超过15秒的死锁进程 ---------------

/*
exec p_lockinfo 0,1;
*/
alter proc p_lockinfo
@kill_lock_spid bit=1, --是否杀掉死锁的进程,1 杀掉, 0 仅显示
@show_spid_if_nolock bit=1 --如果没有死锁的进程,是否显示正常进程信息,1 显示,0 不显示
as
declare @count int,@s nvarchar(1000),@i int
select id=identity(int,1,1),标志,
进程ID=spid,线程ID=kpid,块进程ID=blocked,数据库ID=dbid,
数据库名=db_name(dbid),用户ID=uid,用户名=loginame,累计CPU时间=cpu,等待时间=waittime,
登陆时间=login_time,打开事务数=open_tran, 进程状态=status,
工作站名=hostname,应用程序名=program_name,工作站进程ID=hostprocess,
域名=nt_domain,网卡地址=net_address
into #t from(
select 标志='死锁的进程',
spid,kpid,a.blocked,dbid,uid,loginame,cpu,waittime,login_time,open_tran,
status,hostname,program_name,hostprocess,nt_domain,net_address,
s1=a.spid,s2=0
from master..sysprocesses a join (
select blocked from master..sysprocesses group by blocked
)b on a.spid=b.blocked where a.blocked=0
union all
select '|_牺牲品_>',
spid,kpid,blocked,dbid,uid,loginame,cpu,waittime,login_time,open_tran,
status,hostname,program_name,hostprocess,nt_domain,net_address,
s1=blocked,s2=1
from master..sysprocesses a where blocked<>0
)a order by s1,s2

select @count=@@rowcount,@i=1

if @count=0 and @show_spid_if_nolock=1
begin
insert #t
select 标志='正常的进程',
spid,kpid,blocked,dbid,db_name(dbid),uid,loginame,cpu,waittime,login_time,
open_tran,status,hostname,program_name,hostprocess,nt_domain,net_address
from master..sysprocesses
set @count=@@rowcount
end

if @count>0
begin
create table #t1(id int identity(1,1),a nvarchar(30),b Int,EventInfo nvarchar(4000))
if @kill_lock_spid=1
begin
declare @spid varchar(10),@标志 varchar(10), @等待时间 int
while @i<=@count
begin
select @spid=进程ID,@标志=标志, @等待时间=等待时间 from #t where id=@i
insert #t1 exec('dbcc inputbuffer('+@spid+')')
if @标志='死锁的进程' and @等待时间 >=15000 exec('kill '+@spid)
set @i=@i+1
end
end
else
while @i<=@count
begin
select @s='dbcc inputbuffer('+cast(进程ID as varchar)+')' from #t where id=@i
insert #t1 exec(@s)
set @i=@i+1
end
select a.*,进程的SQL语句=b.EventInfo
from #t a join #t1 b on a.id=b.id
end

GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO

相关文章

最新评论