葡京网上娱乐场vs2010 和vs2012的分别 副标题–Loaded事件走五回

自身上三次博文没有通过首页显示!这边就简单的描述一下题目,希望大拿们有相逢类似题材要么通晓原因的答应弹指间下!!!

一、前言

前几日集团要切换数据库服务器,数据库文件大于2G,结果再附加到另一服务器的数据库里面,就发出了一个问题。如下:

标题:Microsoft SQL Server Management Studio
------------------------------
无法为此请求检索数据。(Microsoft.SqlServer.SmoEnum)
------------------------------
其他信息:
执行 Transact-SQL 语句或批处理时发生了异常。(Microsoft.SqlServer.ConnectionInfo)
------------------------------
E:\DATA\数据库名.mdf 不是主数据库文件。(Microsoft SQL Server,错误:5171)

末段的题目是Loaded事件走三回,具体可以看我上一篇对题目的讲述。

二、解决方案

在网上找了许多措施,最后在CSDN上找到了有关的化解情势,经测试可用。

use master
go
sp_detach_db '数据库名' -- 分离数据库
go
sp_attach_db '数据库名','E:\数据库名.mdf','E:\数据库名.ldf' -- 附加数据库文件
go

网上来看的整治了刹那间。

在SQL Server
7.0中,微软生产了sp_attach_dbsp_attach_single_file_db系统存储过程。
它对于SQL Server数据库管理员执行下边的职责是相当有利于的:

  • sp_attach_db:间接将.MDF和.LDF文件附加到服务器。
  • sp_attach_single_file_db:只附加.MDF文件。
  • sp_detach_db:将数据库从一个服务器分离。复制.MDF文件到另一个服务器上,然后采纳sp_attach_db系统存储过程重新附加那么些文件到六个服务器上。

即便它对于SQL
Server数据库管理员是很有用的,然则在行使这六个存储过程时是有局部限量的。限制如下:

  • 无法附加六个日志文件。
  • 不可以附加16个以上的公文。

在SQL Server
2008中,微软宣布下面的系统存储过程将在以后的版本中被撤除。而她们在”Create
Database”
SQL语句中添加了一个从句”For Attach”。
下边介绍使用”For
Attach”从句的有余主意,以打败在行使sp_attach_db和sp_attach_single_file_db时要面临的范围。

在目的框架同样都是在.net framework
4.0的动静下,用vs2010和用vs2012要么vs2013的结果不同:

三、案例

-- 创建测试数据库
use master
go
CREATE DATABASE TestDB
ON
(
    NAME = TestDB,
    FILENAME = 'D:\TestDB.mdf',
    SIZE = 10,
    MAXSIZE = 50,
    FILEGROWTH = 5,
)
LOG ON
(
    NAME = TestDB_log,
    FILENAME = 'D"\TestDB_log.ldf',
    SIZE = 5MB,
    MAXSIZE = 25MB,
    FILEGROWTH = 5MB
)
GO

-- 现在,让我们分离该数据库,并尝试使用sp_detach_db和sp_attach_db将它重新附加。
-- 执行下面的事务SQL语句。

use master
go
sp_detach_db 'TestDB'
go
sp_attach_db 'TestDB', 'D:\TestDB.mdf', 'D:\TestDB_log.ldf'
go

-- 你也可以使用具有"For Attach"从句的"Create database"命令附加相同的数据库文件,如下所示。

use master
go
sp_detach_db 'TestDB'
go

CREATE DATABASE TestDB
ON
(FILENAME = 'D:\TestDB.mdf'),
(FILENAME = 'D:\TestDB_log.ldf')
For Attach
go

-- 现在,让我们分离数据库TestDB,然后删除.ldf文件,再然后使用sp_attach_single_file_db
-- 系统存储过程通过,执行下面的T-SQL命令将它重新附加上。

use master
go
sp_detach_db 'TestDB'
go
exec master..xp_cmdshell 'del "D:\TestDB_log.ldf"'
go

-- 你可以使用下面的事务SQL语句来激活xp_cmdshell

use master
go
sp_configure 'show advanced options',1
go
reconfigure with override
go
sp_configure 'xp_cmdshell',1
go
reconfigure with override
go

-- 或者,你可以在MS-DOS命令提示符中使用Windows资源管理器的"Del"命令来删除.ldf文件。
-- 现在,让我们只使用sp_attach_single_file_db来附加.MDF文件。执行下面所示的命令。

use master
go
sp_attach_single_file_db 'TestDB','D:\TestDB.mdf'
go

-- 你可以只通过使用带有"For ATTACH_REBUILD_LOG"从句的"Create database"命令来附加
-- 相同的数据库.MDF文件,如下所示。

use master
go
sp_detach_db 'TestDB'
go
exec master..xp_cmdshell 'del "D:\TestDB_log.ldf"'
go

-- 注意:当日志文件被重新创建时,SQL Server自动对日志文件名称添加后缀"_log"。

CREATE DATABASE TestDB
ON
(
    FILENAME = 'D:\TestDB.mdf'
)
For ATTACH_REBUILD_LOG

用vs2010,在事先没有安装vs2012的境况下,Loaded事件走一回。安装完vs2012后Loaded事件走三回。

四、参考

东升哥

私家领悟.net framework 4.0有六个本子,至少vs2010中的.net framework
4.0和vs2012中的.net framework 4.0不等同!

只是网上查找的结果是.net framework 4.0唯有中文版和英文版。