例28.1 查看数据库所在机器操作系统参数(xp_msver)
查看数据库所在机器操作系统参数的存储过程如下
EXEC
master..xp_msver
例28.2 查看当前数据库服务器名(xp_getnetname、HOST_NAME())
EXEC
master..xp_getnetname
或者:
SELECT HOST_NAME()
例28.3
查看服务器上所有Windows本地组(xp_enumgroups)
查看服务器上所有Windows本地组的存储过程如下
EXEC
master..xp_enumgroups
例28.4
查看服务器上安装的所有代码页(xp_enumcodepages)
查看服务器上安装的所有代码页的存储过程如下
EXEC
master..xp_enumcodepages
嘿嘿,是不是报没开启错误啊~~没错误略过
先执行下面语句
USE
master;
GO
EXEC sp_configure 'show advanced option',
'1';
RECONFIGURE
EXEC sp_configure 'Web Assistant
Procedures',1
RECONFIGURE
EXEC sp_configure
例28.5
查看指定目录的所有下一级子目录(xp_subdirs)
查看C:/WINDOWS/Drivers目录所有下一级子目录的存储过程如下
EXEC
[master].[dbo].[xp_subdirs] 'C:/WINDOWS/Drivers'
查看磁盘信息的存储过程如下
EXEC
[master].[dbo].[xp_availablemedia]
或者采用下列语句
EXEC
master..xp_fixeddrives
请注意:其中,low free为以字节为单位的空闲空间,media
type为驱动器类型,软驱为1,硬盘为2,CD-ROM为8。
例28.8
查看硬盘文件信息(xp_dirtree)
查看C盘文件信息的存储过程如下
EXEC master..xp_dirtree
'c:'
查看C盘深度为1的文件信息的存储过程如下
EXEC master..xp_dirtree 'c:',1
查看C盘深度为1、是否为的信息的存储过程如下
EXEC master..xp_dirtree
'c:',1,1
查看“C:/WINDOWS/Web”目录中的文件信息的存储过程如下
EXEC master..xp_dirtree
'C:/WINDOWS/Web'
例28.9
查看服务器提供的OLEDB程序(xp_enum_oledb_providers)
查看服务器提供的OLEDB程序的存储过程如下
EXEC
master..xp_enum_oledb_providers
例28.10
查看数据库服务名(@@SERVERNAME)
print 'SQL Server数据库服务名: ' +
convert(varchar(30),@@SERVERNAME)
查看结果如下:
SQL Server数据库服务名:
SZX/SQLS2008
例28.11 查看数据库实例名(@@SERVICENAME)
PRINT 'SQL
Server数据库实例名: ' +
convert(varchar(30),@@SERVICENAME)
查看结果如下:
SQL Server数据库实例名:
MSSQLSERVER
例28.12
查看DBMS数据库的版本(@@version、sp_msgetversion)
查看DBMS版本的命令如下
SELECT @@version
SQL_Server版本
或者
EXEC master..sp_msgetversion
例28.13
查看数据库配置参数(sp_configure)
查看数据库配置参数的存储过程如下
EXEC sp_configure
例28.14
查看所有数据库名称、容量等信息(sp_helpdb、sp_databases)
sp_helpdb
或sp_databases
查看单个数据库的容量:如sql92_exam_xjgl
sp_helpdb
sql92_exam_xjgl
例28.15
查看所有数据库名称及大小(sp_helpdb)
查看所有数据库名称及大小的存储过程如下
EXEC sp_helpdb
例28.16 修改数据库的名称(sp_renamedb)
EXEC sp_renamedb 'old_dbname',
'new_dbname'
例28.17 查看当前数据库的启动时间(sysprocesses)
SELECT
convert(varchar(30),login_time,120)启动时间
FROM master..sysprocesses
WHERE spid=1
例28.18
查看当前数据库文件路径等信息(sp_helpfile)
sp_helpfile
例28.19
查看AdventureWorks数据库文件路径(sysfiles)
SELECT ltrim(rtrim(filename))
FROM
AdventureWorks..sysfiles
WHERE
charindex('MDF',filename)>0
查看结果如下:
C:/Program Files/Microsoft
SQL Server/100/Tools/Samples/
AdventureWorks_Data.mdf
例28.20
查看当前数据库文件组名(sp_helpfilegroup)
sp_helpfilegroup
例28.21
查看当前数据库中所有的存储过程(sysobjects)
查看当前数据库中所有存储过程的命令如下
SELECT name
as存储过程名称FROM sysobjects WHERE xtype='P'
例28.22
查看数据库里所有的存储过程和函数(sp_stored_procedures)
查看某个数据库里所有存储过程和函数的命令如下
use
AdventureWorks
GO
EXEC sp_stored_procedures
例28.23
查看所有数据库日志文件大小(dbcc sqlperf())
查看所有数据库日志文件大小的命令如下
dbcc
sqlperf(logspace)
例28.24 查看SQL
Server错误日志(xp_enumerrorlogs、xp_readerrorlog)
(1)查看SQL
Server错误日志信息
EXEC master..xp_enumerrorlogs
(2)查看当前错误日志具体内容
EXEC [master].[dbo].[xp_readerrorlog]
例28.25 查看数据库角色信息(sp_helpRole)
查看数据库角色信息的存储过程如下
EXEC
sp_helpRole
例28.26
查看所有数据库用户所属的角色信息(sp_helpsrvrolemember)
查看所有数据库用户所属角色信息的存储过程如下
EXEC
sp_helpsrvrolemember
例28.27
查看角色成员用户信息(sp_helpRoleMember)
查看角色成员用户信息的存储过程如下
EXEC
sp_helpRoleMember 'db_owner'
例28.28
查看当前数据库所有用户信息(sp_helpUser)
查看数据库用户信息的存储过程如下
EXEC sp_helplogins
例28.29
查看本地数据库用户登录信息(sp_helplogins)
查看本地数据库用户登录信息的存储过程如下
EXEC
sp_helplogins
例28.30 查看远端数据库用户登录信息(sp_helpremotelogin
)
查看远端数据库用户登录信息的存储过程如下
EXEC sp_helpremotelogin
例28.31
查看链接服务器的登录信息(sp_helplinkedsrvlogin)
查看链接服务器信息的存储过程如下
EXEC
sp_helplinkedsrvlogin
例28.32
将用户账户添加到数据库中(sp_grantdbaccess)
将guest用户账户添加到数据库中的命令如下:
USE
sql92_exam_xjgl
GO
EXEC sp_grantdbaccess guest
例28.33
查看数据库下对象级用户权限(sp_helprotect)
查看数据库下对象级用户权限的存储过程如下
EXEC
sp_helprotect
例28.34
获得当前数据库所有用户表的名称(sysobjects)
获得当前数据库所有用户表名称的命令如下
SELECT OBJECT_NAME
(id)
FROM sysobjects
WHERE xtype = 'U' AND OBJECTPROPERTY (id,
'IsMSShipped') = 0
例28.36
查询单个用户创建的所有数据库(sysdatabases)
查询sa用户创建的所有数据库的命令如下
SELECT
name,dbid,filename
FROM master..sysdatabases D
WHERE sid not
in(SELECT sid FROM master..syslogins WHERE
name='sa')
或者通过以下命令实现:
SELECT dbid, name AS DB_NAME,filename
FROM master..sysdatabases
WHERE sid <>
0x01
例28.37
查看一个表上相关的对象(sysobjects、syscomments)
查询一个表上相关对象的命令如下
SELECT a.*
FROM sysobjects a, syscomments b
WHERE a.id = b.id and b.text like
'%teacher%'
例28.38
获取某一个表的所有字段(syscolumns、sp_mshelpcolumns)
获取某一个表的所有字段的命令如下
SELECT
name FROM syscolumns WHERE
id=object_id('teacher')
或者通过以下存储过程实现
EXEC sp_mshelpcolumns
'teacher'
例28.39
获得指定表上所有的索引名称(sysindexes)
通过系统表sysindexes获得指定表上所有索引名称的命令如下
SELECT
name FROM sysindexes
WHERE id = OBJECT_ID ('dept') AND indid >
0
例28.40
查询某一个表的字段和数据类型(information_schema.columns)
查询某一个表的字段和数据类型的命令如下
SELECT
column_name,data_type
FROM information_schema.columns
WHERE
table_name = N'teacher'
例28.41
获取某一个表的基本信息(sp_MShelpcolumns)
获取某一个表的基本信息的存储过程如下
EXEC
sp_MShelpcolumns N'teacher'
例28.42
获取某一个表的主键、外键信息(sp_pkeys、sp_fkeys)
获取表teacher的主键信息的存储过程如下
EXEC
sp_pkeys N'teacher'
获取表teacher的外键信息的存储过程如下:
EXEC sp_fkeys
N'teacher'
例28.43
判断某一个表是否存在某一字段(syscolumns)
通过系统表syscolumn判断某一个表是否存在某一字段的命令如下:
if
exists(SELECT 1 FROM syscolumns
WHERE
id=object_id(N'teacher') and name=N'tname')
print
N'存在'
else
print N'不存在'
例28.44
查看单个存储过程和函数的源代码(sp_helptext)
查看单个存储过程和函数源代码的存储过程如下
USE
AdventureWorks
GO
EXEC sp_helptext 'dbo.uspLogError'
例28.45 查看数据库里用户和进程的信息(sp_who)
(1)查看数据库里用户和进程信息
EXEC sp_who
其中,spid是进程编号,进程号1--50是SQL
Server系统内部用的,进程号大于50的是用户的连接进程。
(2)查看活动用户和进程信息的存储过程如下
EXEC sp_who
'active'
例28.46
清除sleeping进程(Kill__Sleeping_Processes)
Sleeping进程是系统中处于睡眠状态尚未活动的进程,这部分进程可以杀掉。
CREATE
PROCEDURE dbo.Kill__Sleeping_Processes @dbname varchar(50)
AS
BEGIN
SET NOCOUNT ON
DECLARE @spid INT,
@cnt
INT,
@sql VARCHAR(255)
SELECT @spid = MIN(spid),@cnt = COUNT(*)
FROM master..sysprocesses
WHERE dbid = DB_ID(@dbname) AND spid
!= @@SPID AND status = 'sleeping'
WHILE @spid IS NOT NULL
BEGIN
SET @sql = 'KILL ' + RTRIM(@spid)
EXEC ( @sql )
SELECT
@spid = MIN(spid),@cnt = COUNT(*)
FROM master..sysprocesses
WHERE dbid = DB_ID(@dbname) AND spid != @@SPID AND status =
'sleeping'
END
END
GO
运行改存储过程后杀掉sleeping进程:
Kill__Sleeping_Processes
SQLS2008
清除前后可以用EXEC sp_who 'active '进行查看。
例28.47
查看进程正在执行的SQL语句(dbcc inputbuffer ())
查看进程正在执行的SQL语句:dbcc inputbuffer
(spid)
其中spid是用sp_who查询出来的spid号,如:56。
查看56号进程正在执行的SQL语句实例如下
dbcc
inputbuffer (56)
例28.48 查看数据库锁(sp_lock)
查看SQL
Server数据库里锁的情况的存储过程如下
EXEC sp_lock
其中,spid是进程编号,dbid是数据库编号,Objid是数据对象编号。
例28.49
查看数据库死锁的进程(proc_who_lock)
用proc_ find _lock过程查看数据库死锁的进程。
if exists
(SELECT *
FROM dbo.sysobjects
WHERE id =
object_id(N'[dbo].[proc_find_lock]')
and OBJECTPROPERTY(id,
N'IsProcedure') = 1)
drop procedure
[dbo].[proc_find_lock]
GO
use master
go
create
procedure proc_find_lock
as
begin
declare @spid int,@bl
int,
@intTransactionCountOnEntry int,
@intRowcount
int,
@intCountProperties int,
@intCounter
int
create table #temp_lock (
id int identity(1,1),
spid
smallint,
bl smallint)
IF @@ERROR<>0 RETURN
@@ERROR
insert into #temp_lock(spid,bl)
SELECT 0
,blocked
FROM (SELECT * FROM sysprocesses WHERE blocked>0 ) a
WHERE not exists(SELECT *
FROM (SELECT *
FROM sysprocesses
WHERE blocked>0 ) b
WHERE a.blocked=spid)
union SELECT
spid,blocked
FROM sysprocesses
WHERE
blocked>0
IF @@ERROR<>0 RETURN @@ERROR
SELECT
@intCountProperties = Count(*),@intCounter = 1 --找到临时表的记录数
FROM
#temp_lock
IF @@ERROR<>0 RETURN @@ERROR
if
@intCountProperties=0
SELECT '没有阻塞和死锁信息' as 提示
while
@intCounter <= @intCountProperties
begin
SELECT @spid =
spid,@bl = bl
FROM #temp_lock WHERE Id = @intCounter
begin
if @spid =0
SELECT '引起数据库死锁的进程号是: '+ CAST(@bl
AS VARCHAR(10))
+ ',其执行的SQL语句为:'
else
SELECT '进程号SPID:'+ CAST(@spid AS VARCHAR(10))
+ '被' +
'进程号SPID:'+ CAST(@bl AS VARCHAR(10))
+'阻塞,其当前进程执行的SQL语句为:'
DBCC INPUTBUFFER (@bl )
end
set
@intCounter = @intCounter + 1
end
drop table
#temp_lock
return
0
end
运行过程proc_find_lock
proc_find_lock
例28.50
备份当前数据库(backup database)
(1)完全备份
declare @a sysname,@s
nvarchar(4000)
SELECT @a=db_name(),@s='e:/sql_db_bak_full' backup
database @a to disk=@s WITH
format
已为数据库'sql92_exam_xjgl',文件'sql92_example'(位于文件1上)处理了240页。
已为数据库'sql92_exam_xjgl',文件'sql92_example_log'(位于文件1上)处理了1页。
BACKUP
DATABASE成功处理了241页,花费0.101秒(19.547 MB/秒)。
(2)差异备份
declare @a
sysname,@s nvarchar(4000)
SELECT @a=db_name(),@s='e:/sql_db_bak_diff'
backup database @a to disk=@s WITH
DIFFERENTIAL,format
已为数据库'sql92_exam_xjgl',文件'sql92_example'
(位于文件1上)处理了40页。
已为数据库'sql92_exam_xjgl',文件'sql92_example_log'
(位于文件1上)处理了1页。
BACKUP DATABASE WITH DIFFERENTIAL成功处理了41页,花费0.095秒(3.530
MB/秒)。
差异备份要在至少有一次完全备份成功之后才能实施,否则出错。
例28.51
从磁带中恢复完整的数据库备份
从磁带中恢复sql92_exam_xjgl的完整数据库备份。
USE
master
GO
RESTORE DATABASE sql92_exam_xjgl
FROM TAPE =
'//./Tape0'
GO
例28.52
在脱机状态下进行数据库备份和恢复
在脱机状态下对sql92_exam_xjgl数据库进行备份和恢复。
步骤如下:
卸载需要进行备份恢复的sql92_exam_xjgl数据库。
在master数据库下新建下列查询分析语句:
Sp_detach_db
'sql92_exam_xjgl'
运行结果为:命令已成功完成。
复制sql92_exam_xjgl
库的sql92_example.mdf文件和sql92_example_log.ldf文件到E:/下。
启动数据库服务器进行恢复。
sp_attach_db
'sql92_exam_xjgl',
'E:/sql92_example.mdf', 'E:/sql92_example_log.ldf'
运行结果为:命令已成功完成。
当恢复单个mdf文件采用下列语句:
sp_attach_single_file_db
'sql92_exam_xjgl','E:/sql92_example.mdf''

被折叠的 条评论
为什么被折叠?



