• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    mssql server 数据库附加不上解决办法分享

    image

    错误15105,从网上找了一些解决方案,一般都是说文件的权限不足的问题,

    当然附加的时候必须是有数据库附加权限才可以操作的。

    解决办法1:给相应的MDF文件给Full Control的权限,如果不知道是什么用户可以去Sql Server的配置中心去找

    但是我遇到这个用上述方法就不可以。

    解决方法2:换个用户试试,我原数据库是用sa登陆的,我试着用sa登陆一下,附加成功了!~

    如果反复的用sa登陆却登陆失败,可能是没有开权限。

    权限可以在登陆用户的选项中设置,允许登陆即可。

    验证模式则可以在服务器处设置,要选择混合登陆模式。

    image

    另外对高版本数据附加低版本数据库也可以试试上面的方法。

    其实我个人更喜欢用生成脚本的方式导结构和数据。

    image
    在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错误的解决方法

    您可能感兴趣的文章:
    • sql server2005实现数据库读写分离介绍
    • SQL Server 2005附加数据库时Read-Only错误的解决方案
    • sql server2012附加数据库问题解决方法
    • Sqlserver 2005附加数据库时出错提示操作系统错误5(拒绝访问)错误5120的解决办法
    • sqlserver附加.mdf权限问题解决
    • MSSQL2005在networkservice权限运行附加数据库报(Microsoft SQL Server,错误: 5120)
    • SQL SERVER 2008 无法附加数据库的解决方法
    • SQLServer 附加数据库后出现只读或失败的解决方法
    • mssql server .ldf和.mdf的文件附加数据库的sql语句
    • SQL Server 数据库分离与附加 就这么简单!
    上一篇:sqlserver中在指定数据库的所有表的所有列中搜索给定的值
    下一篇:在数据库‘master’中拒绝CREATE DATABASE权限问题的解决方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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