SQL Server 修改数据库名称 您所在的位置:网站首页 sqlServer导出无法指定数据库名称 SQL Server 修改数据库名称

SQL Server 修改数据库名称

2024-07-11 22:24| 来源: 网络整理| 查看: 265

一、 准备工作

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

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

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';

参考

https://www.cnblogs.com/kerrycode/archive/2013/04/25/3043764.html



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有