• 售前

  • 售后

热门帖子
入门百科

mssql server 数据库附加不上解决办法分享

[复制链接]
枣强公用号 显示全部楼层 发表于 2021-10-26 13:33:35 |阅读模式 打印 上一主题 下一主题
[img=485 border=0,170 alt=image src=]https://www.caogenba.net/[/img]
错误15105,从网上找了一些办理方案,一样平常都是说文件的权限不敷的问题,
固然附加的时候必须是有数据库附加权限才可以操作的。
办理办法1:给相应的MDF文件给Full Control的权限,如果不知道是什么用户可以去Sql Server的配置中央去找
但是我遇到这个用上述方法就不可以。
办理方法2:换个用户试试,我原数据库是用sa登陆的,我试着用sa登陆一下,附加成功了!~
如果反复的用sa登陆却登陆失败,大概是没有开权限。
权限可以在登陆用户的选项中设置,允许登陆即可。
验证模式则可以在服务器处设置,要选择混合登陆模式。
[img=595 border=0,396 alt=image src=]https://www.caogenba.net/[/img]
别的对高版本数据附加低版本数据库也可以试试上面的方法。
实在我个人更喜好用天生脚本的方式导布局和数据。
[img=350 border=0,317 alt=image src=]https://www.caogenba.net/[/img]
在QA里实行sp_attach_db或者sp_attach_single_file_db,出现提示:错误1813:未能打开新数据库'dbname',create database 将停止。设备激活错误。物理文件名'd:\sql server\mssql\data\dbname _log.ldf'大概有误!
  按下面的步调处置惩罚:
  1.新建一个同名的数据库
  2.再停掉sqlserver服务(留意不要分离数据库)
  3.用原数据库的数据文件覆盖掉这个新建的数据库
  4.再重启sqlserver服务
  5.此时打开企业管理器时会出现置疑,先不管,实行下面的语句(留意修改此中的数据库名)
  6.完成后一样平常就可以访问数据库中的数据了。这时,数据库本身一样平常另有问题,办理办法是:使用数据库的脚本创建一个新的数据库,然后通过DTS将数据导进去就行了
复制代码 代码如下:
use master go sp_configure 'allow updates',1 reconfigure with override go update sysdatabases set status =32768 where name='置疑的数据库名' go sp_dboption '置疑的数据库名', 'single user', 'true' go dbcc checkdb('置疑的数据库名') go update sysdatabases set status =28 where name='置疑的数据库名' go sp_configure 'allow updates', 0 reconfigure with override go sp_dboption '置疑的数据库名', 'single user', 'false' go


Sql Server 2000附加数据库出现1813错误的办理方法

本日进行了一错误操作。

数据库xxzx_discuz,因天生大量日志使日志文件'xxzx_discuz_Log.LDF' 占满了磁盘全部空间,使网站无法正常使用数据库。

本身图省事分离数据库xxzx_discuz后,直接删除'xxzx_discuz_Log.LDF' (由于文件太大,无法存放到回收站),重新附件到SQL Server时出现两个提示:
------------------------------------------------------------------------------------------------------------------------------
SQL Server 企业管理器
---------------------------
为日志文件指定的文件名不精确。
将创建新的日志文件。
要继续吗?
---------------------------
是(Y) 否(N)
------------------------------------------------------------------------------------------------------------------------------
Microsoft SQL-DMO (ODBC SQLState: 42000)
---------------------------
错误 1813: 未能打开新数据库 'xxzx_discuz'。CREATE DATABASE 将停止。
设备激活错误。物理文件名 'S:\Program Files\Microsoft SQL Server\MSSQL\data\xxzx_discuz_Log.LDF' 大概有误。
---------------------------
确定
------------------------------------------------------------------------------------------------------------------------------

从而无法将数据库正常附加到SQL Server 2000,正常情况下这样操作是没有问题的,SQL Server会重新天生日志文件,但是由于之前出现了磁盘空间不敷,日志文件不完备,从而造成了无法正常附加。

办理办法如下(从网上找来的):

0.备份数据文件'xxzx_discuz_Log.MDF'
1.新建一个同名的数据库'xxzx_discuz'
2.再停掉sqlserver服务(留意不要分离数据库)
3.用原数据库的数据文件'xxzx_discuz_Log.MDF' 覆盖掉新建的数据库

4.再重启sqlserver服务
5.此时打开企业管理器时会出现置疑,先不管,实行下面的语句(留意修改此中的数据库名) 6.完成后一样平常就可以访问数据库中的数据了。这时,数据库本身一样平常另有问题,办理办法是:使用数据库的脚本创建一个新的数据库,然后通过DTS将数据导进去就行了. SQL代码
复制代码 代码如下:
use master
go
sp_configure 'allow updates',1 reconfigure with override
go
update sysdatabases set status =32768 where name='置疑的数据库名'
go
sp_dboption '置疑的数据库名', 'single user', 'true'
go
dbcc checkdb('置疑的数据库名')
go
update sysdatabases set status =28 where name='置疑的数据库名'
go
sp_configure 'allow updates', 0 reconfigure with override
go
sp_dboption '置疑的数据库名', 'single user', 'false'
go

特别留意最后一步中的说明“这时,数据库本身一样平常另有问题,办理办法是:使用数据库的脚本创建一个新的数据库,然后通过DTS将数据导进去就行了” 参考文章:Sql Server附加数据库出现1813错误的办理方法

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作