重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
其实在修改数据库名称之前,如果有用户连接到数据库的话会造成数据库重命名失败,可以先执行
创新互联拥有网站维护技术和项目管理团队,建立的售前、实施和售后服务体系,为客户提供定制化的成都网站制作、成都网站建设、网站维护、成都服务器托管解决方案。为客户网站安全和日常运维提供整体管家式外包优质服务。我们的网站维护服务覆盖集团企业、上市公司、外企网站、电子商务商城网站建设、政府网站等各类型客户群体,为全球上千余家企业提供全方位网站维护、服务器维护解决方案。
select
spid
from
master.dbo.sysprocesses
where
dbid=db_id('OldDbName')
结果集中显示的是当前连接到数据库OldDbName的连接
比如结果是
79
81
当然,实际值应该不是这两个
然后执行
kill
79
kill
81
关闭已建立的连接,之后再执行
EXEC
sp_dboption
'OldDbName',
'Single
User',
'TRUE'
EXEC
sp_renamedb
'OldDbName',
'NewDbName'
EXEC
sp_dboption
'NewDbName',
'Single
User',
'FALSE'
上述语句最好都在master数据库中执行。
另外也可以这样:
先分离数据库,然后附加的时候再修改就可以了
SQL
Server不支持直接修改数据库名称
一、未使用的数据库
改名方法如下:
1、未使用的数据库改名比较方便,找到你要更改的数据库,右键选择【重命名】。
2、然后将你想要更改的名字写好,然后点击一下旁边的空白栏。
3、然后你就发现数据库的名称已经改好了。
二、使用中的数据库改名方法如下:
1、使用中的数据库你在使用这种方法显然是不合适,你用这种方法更改数据库的名字之后会提示你无法重命名数据库。
2、这时还是同样的右键你要改名的数据库,选择【属性】按钮。
3、然后在数据库属性左侧菜单栏中选择【选项】按钮。
4、然后在【状态】栏目下有一项限制访问选项,默认的是MULTI_USER,意为多用户模式,然后你将其更改为【SINGLE_USER】单用户模式,点击确定即可。
5、然后你在使用上面的方法更改数据库的名称会发现数据库改名成功了。
企业管理器中没有改数据库名的功能,如果一定要用企业管理器来实现,你可以备份数据库,然后还原,在还原时候可以指定另一个库名,然后再删除旧库就行了。
这里以
SQLServer
20000
为例,旧数据库名字为
Admin10000,
新数据库名字为
jb51.net。
第一步、备份数据库
打开企业管理器
--
右键一个数据库
--
所有任务
--
备份数据库
--
目的--备份到中选择添加
--
输入一个备份的文件名(注意,如果原来有文件名,要删除它)
--
确定
第二步、还原数据库,并指定一个新库名,并且修改物理文件名。
企业管理器--右键
"数据库
"--所有任务--还原数据库
--
"还原为数据库库"
中输入还原后的数据库名
jb51.net
--
还原选择
"从设备
"--选择设备--添加--添加你的备份文件--确定,回到数据库还原的界面
--
备份号--选择内容--选择你要恢复那次备份的内容
--
选项--将
"移至物理文件名
"中的物理文件名修改为你的数据文件要存放的文件名,这里修改为
jb51.net_Data.MDF(数据库文件)
和
jb51.net_Log.LDF(日志文件)
--
如果要还原的数据库已经存在,选择
"在现有数据库上强制还原
"
--
确定
第三步、修改逻辑文件名
如果想修改逻辑文件名,可以查询分析器里输入
alter
database
[jb51.net]
modify
file
(
name='Admin10000_Data',
newname='jb51.net_Data')
alter
database
[jb51.net]
modify
file
(
name='Admin10000_log',
newname='jb51.net_log')
第四步、最后删除旧的数据库 jb51
企业管理器
--右键"数据库"--所有任务--还原数据库
--"还原为数据库库"中输入还原后的数据库名Admin10000.com
--还原选择"从设备"--选择设备--添加--添加你的
备份文件
--确定,回到数据库还原的界面
--备份号--选择内容--选择你要恢复那次备份的内容
--选项--将"移至物理文件名"中的物理文件名修改为你的
数据文件
要存放的文件名,这里修改为Admin10000.com_Data.MDF(
数据库文件
)和Admin10000.com_Log.LDF(
日志文件
)
--如果要还原的数据库已经存在,选择"在现有数据库上强制还原"
--确定