阅读排行榜

评论排行榜

最新评论

总感觉那个叫啥晓峰的回复,总是不那么切题,貌似只看到了最基础的用处 --【匿名用户】:E-works热心网友
这是个好建议! --【匿名用户】:E-works鐑績缃戝弸
所以国内企业要的就是灵活不是标准。 --【匿名用户】:E-works热心网友
写进BOM的都是标准成本,实际业务中按照标准成本来的有多少啊。 --【匿名用户】:E-works热心网友
这个有这个复杂? --【匿名用户】:E-works热心网友
建议还是挺好的。 --苌晓峰
这个分享还是蛮不错的吗! --苌晓峰
太简单了啊 --苌晓峰
分享 --苌晓峰
真正用得时候,谁还会想到这个啊 --苌晓峰

【转】贴个SQL小工具--移动数据库物理文件
本文标签: SQL小工具 移动数据库 

 无意间发现个移动数据库物理文件的小工具,很不错贴出来与大家分享。

已经适用大多数情况(SQLServer2005/2008):

SQL code

USE master

GO

DECLARE

@DBName sysname,

@DestPath varchar(256)

DECLARE @DB table(

name sysname,

physical_name sysname)

BEGIN TRY

SELECT

@DBName = 'FF',   --input database name

@DestPath = 'E:\' --input destination path

--kill database processes

DECLARE @SPID varchar(20)

DECLARE curProcess CURSOR FOR

SELECT spid

FROM sys.sysprocesses

WHERE DB_NAME(dbid) = @DBName

OPEN curProcess

FETCH NEXT FROM curProcess INTO @SPID

WHILE @@FETCH_STATUS = 0

BEGIN

EXEC('KILL ' + @SPID)

FETCH NEXT FROM curProcess

END

CLOSE curProcess

DEALLOCATE curProcess

--query physical name

INSERT @DB(

name,

physical_name)

SELECT

A.name,

A.physical_name

FROM sys.master_files A

INNER JOIN sys.databases B

ON A.database_id = B.database_id

AND B.name = @DBName

WHERE A.type <=1

--set offline

EXEC('ALTER DATABASE ' + @DBName + ' SET OFFLINE')

--move to dest path

DECLARE

@login_name sysname,

@physical_name sysname,

@temp_name varchar(256)

DECLARE curMove CURSOR FOR

SELECT

name,

physical_name

FROM @DB

OPEN curMove

FETCH NEXT FROM curMove INTO @login_name,@physical_name

WHILE @@FETCH_STATUS = 0

BEGIN

SET @temp_name = RIGHT(@physical_name,CHARINDEX('\',REVERSE(@physical_name)) - 1)

EXEC('exec xp_cmdshell ''move "' + @physical_name + '" "' + @DestPath + '"''')

EXEC('ALTER DATABASE ' + @DBName + ' MODIFY FILE ( NAME = ' + @login_name

+ ', FILENAME = ''' + @DestPath + @temp_name + ''')')

FETCH NEXT FROM curMove INTO @login_name,@physical_name

END

CLOSE curMove

DEALLOCATE curMove

--set online

EXEC('ALTER DATABASE ' + @DBName + ' SET ONLINE')

--show result

SELECT

A.name,

A.physical_name

FROM sys.master_files A

INNER JOIN sys.databases B

ON A.database_id = B.database_id

AND B.name = @DBName

END TRY

BEGIN CATCH

SELECT ERROR_MESSAGE() AS ErrorMessage

END CATCH

发表于: 2009-08-14 12:20 秋声 阅读(980) 评论(0) 收藏 好文推荐

发表评论(网友发言只代表个人观点,不代表本网站观点或立场。)

您尚未登录,请先【登录或注册