代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
MSSQL
】
修改 数据库文件名(逻辑文件名)
作者:
Dezai.CN
/ 发布于
2013/3/26
/
767
--修改 数据库文件名(逻辑文件名) DECLARE @name VARCHAR(64) DECLARE @i INT, @j INT, @count INT DECLARE @newname VARCHAR(164) DECLARE @db_name VARCHAR(132) DECLARE @sql NVARCHAR(1200) DECLARE @sql_use NVARCHAR(1200) DECLARE @sql_get_file_count NVARCHAR(2400) DECLARE @use_db VARCHAR(132) DECLARE @file_count INT SET @file_count =1--任何一个数据库 默认有两个文件(一个数据文件一个日志文件) SET @j=1---数据库数据量循环变量 ---获取数据库总数量 SELECT @count = Count(*) FROM sys.databases WHERE database_id > 4 WHILE @j <= @count BEGIN ----获取数据库名 SELECT @db_name = name FROM (SELECT Row_number() OVER( ORDER BY database_id)rn, name FROM sys.databases WHERE database_id > 4 )a WHERE rn = @j SET @i=1 SET @sql_get_file_count=N' use ' + @db_name + '' + Char(10) + Char(13) + 'select @file_count=count(1) from sys.database_files where type_desc=''ROWS''' ---type_desc=''ROWS''为 数据文件 type_desc=''LOG'' 为日志文件 ---获取数据库文件数量 EXEC Sp_executesql @sql_get_file_count, N'@db_name nvarchar(32),@file_count int OUTPUT', @db_name, @file_count OUTPUT WHILE @i <= @file_count BEGIN SET @sql_use =N' use ' + @db_name + '' + Char(10) + Char(13) + 'select @name=name from (select row_number() over(order by name)rn,name from sys.database_files where type_desc=''ROWS'')tmp where rn =@i ' ---type_desc=''ROWS''为 数据文件 type_desc=''LOG'' 为日志文件 ---获取现 逻辑文件名 EXEC Sp_executesql @sql_use, N'@db_name nvarchar(32),@name varchar(64) OUTPUT,@i int ', @db_name, @name OUTPUT, @i ---构造文件最终修改成的格式 SET @newname =@db_name+'_log' --这里需要注意修改的日志文件还是数据文件。这里只简单的将文件改成了和数据库名相同的名称 if rtrim(ltrim(@newname))!=rtrim(ltrim(@name)) begin SET @sql='alter database ' + @db_name + ' modify file (name=''' + @name + ''' ,newname=''' + @newname + ''')' ---修改逻辑文件名 EXEC Sp_executesql @sql, N'@db_name nvarchar(32),@name varchar(64),@newname varchar(64)', @db_name, @name, @newname end ---循环逻辑文件数量的变量 SET @i+=1 END ---循环数据库数量的变量 SET @j+=1 END
试试其它关键字
数据库文件名
同语言下
.
SQL查询 多列合并成一行用逗号隔开
.
查看存储过程修改时间,最近执行时间
.
设置手动批量删除数据库相关进程
.
获取某个表中特定字段的所有字符串形式
.
SQL 如何去除重复的字符串
.
怎么去掉一个字段中的重复数据
.
String 去除空格 回车 换行 水平制表符
.
SQL查询和替换含有回车,空格,TAB
.
SQL SERVER 查询每日新增用户数量、次留数量
.
判断两个字符串是否存在相同的内容
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
Dezai.CN
贡献的其它代码
(
4037
)
.
多线程Socket服务器模块
.
生成随机密码
.
清除浮动样式
.
弹出窗口居中
.
抓取url的函数
.
使用base HTTP验证
.
div模拟iframe嵌入效果
.
通过header转向的方法
.
Session操作类
.
执行sqlite输入插入操作后获得自动编号的ID
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3