MsSql

关注公众号 jb51net

关闭
首页 > 数据库 > MsSql > SQL Server修改数据库名称

SQL Server修改数据库名称的常用方法

作者:Hehuyi_In

本文详细介绍如何在SOLServer中更改数据库名称,包括通过图形界面、ALTER DATABASE命令及使用SP RENAMEDB系统存储过程的方法,并提供确保操作成功的前置步骤如杀死会话或设置单用户模式,需要的朋友可以参考下

一、 准备工作

改名时如果有其他用户会话连接该数据库会报错,必须先杀掉那些用户会话或使数据库处于单用户模式下再执行。

查询当前有哪些会话连接到这个数据库

SELECT SPID FROM master.dbo.sysprocesses WHERE dbid=DB_ID('Test1');

如果有,执行KILL命令杀掉

KILL SPID

也可以将数据库设置为单用户模式。在数据库属性 -> “连接”页面 找到“限制访问”选项,选择SIGLE_USER。

clip_image002[4]

命令行

use master
-- 设置单用户
exec sp_dboption  @dbname='OldDbName', @optname= 'Single User',@optvalue= 'TRUE'
-- 恢复多用户
exec sp_dboption  @dbname='NewDbName', @optname= 'Single User', @optvalue='FALSE'
GO

二、 修改数据库名称

1. 图形界面修改

clip_image002

2. ALTER DATABASE

USE master;
GO
ALTER DATABASE Test1 MODIFY NAME = Test;
GO

或者设置为单用户模式再改

ALTER DATABASE db名 SET SINGLE_USER WITH ROLLBACK IMMEDIATE;
ALTER DATABASE 旧db名 MODIFY NAME = 新db名;
ALTER DATABASE db名 SET MULTI_USER;

3. SP_RENAMEDB系统存储过程

注意:SQL Server 2008后续版本将删除该功能。

语法: sp_renamedb [ @dbname = ] 'old_name' , [ @newname = ] 'new_name'

例子: 将数据库Test_1的名称修改为Test

use master
go
exec sp_renamedb @dbname='Test_1', @newname='Test';
go

直接利用脚本修改

use master
exec sp_dboption  @dbname='OldDbName', @optname= 'Single User',@optvalue= 'TRUE'
exec sp_renamedb  @dbname='OldDbName', @newname= 'NewDbName'
exec sp_dboption  @dbname='NewDbName', @optname= 'Single User', @optvalue='FALSE'
GO

检查修改成功

SELECT name, database_id FROM sys.databases WHERE name = N'DbName';

到此这篇关于SQL Server修改数据库名称的常用方法的文章就介绍到这了,更多相关SQL Server修改数据库名称内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文