SQL Server 无法启动的原因定位、首先要知道SQL Server 启动的过程。

第一步:

读取注册表,创建log文件、检测硬件、初始化系统配置。

第二步:

启动系统数据库。

第三步:

准备好网络连接。

第四步:

启动用户数据库。

--------------------------------------------------------------------------------------------------------------------------------------------------------------

方法 1、 针对第一步

运行--> regedit       打开注册表

Windows Server 2012 +SQL Server 2012 情况下SQL Server 的键值对在

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\.........下

1、当前用户没有读取注册表权限时SQL Server 在第一步时就失败了,所以不能启动。

运行 --> eventwvr          (event viewer)可以查看日志文件。

单击每一个信息可以查看它的全部内容。

有了这个日志文件后有什么错都可以从日志文件中找到答案了,是不是太爽了。

然---

2、如果日志文件不能被成功的创建SQL server也不可以被启动。

方法 2、针对第二步

启动master 数据库是一人重要阶段,如果master数据库不能正常启动,数据库也就不能启动。

1、在指定路径下找不到master的文件、路径不对。

2、文件是找到了但是没有权限、

3、文件损坏了、

你有没有想过为什么我知道大概是这三个问题,我会告诉你这是经验。但是你遇到了怎么办,一个办法,就是看日志,来定位错误的原因。

解决方法

1、 恢复master 原来的备份。

2、取物相应的权限。

启动 Model 系统数据库出错时原因也与master 差不多吧。

解决方法

1、 恢复master 原来的备份。

2、取物相应的权限。

3、在启动数据库时路过恢复Model这一个环节

第一步、用参数启动SQL Server

net start MSSQLSERVER  /f /m /T3608

第二步、恢复Model 数据库

restore database Model from disk = 'E:\Model.bak';

启动 tempdb 出错,服务器上可能没有那么多空间放tempdb

解决方法

第一步:用参数启动

net start MSSQLSERVER /f /m /T3608

第二步:

alter database tempdb modify file(name =tempdev,size=100MB);

alter database tempdb modify file(name = templog,size=200MB);

方法 3、针对第三步

网络连接出错,一般看来是端口被别的程序用了。

解决方法:

SQL server 用的是1433端口、所以我们只要找到是哪个不脸的程序用了这个端口再把它kill了就可以了。

运行--> netstat

注意:

SQL Server 在启动完 master 后 tempdb 与准备网张连接是同时进行的。

方法 4、针对第四步

数据库文件有三种  1主数据库文件 mdf、 2次要文件 ndf 、 3日志文件 ldf。

不管是哪一个文件坏了数据库都不会成常启动。

1、 完整还原数据库  restore database........

2、 如果只是个别ndf 坏了、可以用文件还原

第一步:alter database Studio modify file(name = Studio2,offline);----把坏了的文件设为离线。

第二步:alter database Studio set online;把数据库设为在线。

第三步:还原出坏的文件组。

3、日志文件损坏了就有点不好了,慢慢听

在simple 恢复模式下如果上次数据库是正常关闭(所有提交的事务都写入硬盘,所有回滚的事务都以撤销)的就算没有ldf文件

数据库还是可以启动的。

如果ldf 文件损坏最好的恢复办法就是恢复数据库备份、因为有时数据库可以处于一个不一致的状态,如事务提交了,但是数据只在

日志文件里,如果用户可以接受这样的损失,可以选择dbcc checkdb 的方法修复数据库

首先:

1、 alter database Studio set Emerggency;

2、 alter database Studio set single_user;

3、 dbcc checkdb(Studio,repair_allow_data_loss);

SQL Server 无法启动的 4 种原因的更多相关文章

  1. 你所不知道的SQL Server数据库启动过程,以及启动不起来的各种问题的分析及解决技巧

    目前SQL Server数据库作为微软一款优秀的RDBMS,其本身启动的时候是很少出问题的,我们在平时用的时候,很少关注起启动过程,或者很少了解其底层运行过程,大部分的过程只关注其内部的表.存储过程. ...

  2. 你所不知道的SQL Server数据库启动过程(用户数据库加载过程的疑难杂症)

    前言 本篇主要是上一篇文章的补充篇,上一篇我们介绍了SQL Server服务启动过程所遇到的一些问题和解决方法,可点击查看,我们此篇主要介绍的是SQL Server启动过程中关于用户数据库加载的流程, ...

  3. (4.21)SQL Server数据库启动过程(用户数据库加载过程的疑难杂症)

    转自:指尖流淌 http://www.cnblogs.com/zhijianliutang/p/4100103.html SQL Server数据库启动过程(用户数据库加载过程的疑难杂症) 前言 本篇 ...

  4. (4.20)SQL Server数据库启动过程,以及启动不起来的各种问题的分析及解决技巧

    转自:指尖流淌 https://www.cnblogs.com/zhijianliutang/p/4085546.html SQL Server数据库启动过程,以及启动不起来的各种问题的分析及解决技巧 ...

  5. SQL Server 数据库启动过程(用户数据库加载过程的疑难杂症)

    前言 本篇主要是上一篇文章的补充篇,上一篇我们介绍了SQL Server服务启动过程所遇到的一些问题和解决方法,可点击查看,我们此篇主要介绍的是SQL Server启动过程中关于用户数据库加载的流程, ...

  6. SQL Server 数据库启动过程(用户数据库加载过程的疑难杂症)

    前言 本篇主要是上一篇文章的补充篇,上一篇我们介绍了SQL Server服务启动过程所遇到的一些问题和解决方法,可点击查看,我们此篇主要介绍的是SQL Server启动过程中关于用户数据库加载的流程, ...

  7. SQL Server 数据库启动过程,以及启动不起来的各种问题的分析及解决技巧

    目前SQL Server数据库作为微软一款优秀的RDBMS,其本身启动的时候是很少出问题的,我们在平时用的时候,很少关注起启动过程,或者很少了解其底层运行过程,大部分的过程只关注其内部的表.存储过程. ...

  8. SQL Server 优化存储过程的七种方法

    原文:SQL Server 优化存储过程的七种方法 优化存储过程有很多种方法,下面介绍最常用的7种. 1.使用SET NOCOUNT ON选项 我们使用SELECT语句时,除了返回对应的结果集外,还会 ...

  9. SQL Server遍历表的几种方法 转载

    SQL Server遍历表的几种方法 阅读目录 使用游标 使用表变量 使用临时表 在数据库开发过程中,我们经常会碰到要遍历数据表的情形,一提到遍历表,我们第一印象可能就想到使用游标,使用游标虽然直观易 ...

随机推荐

  1. bzoj1623 [Usaco2008 Open]Cow Cars 奶牛飞车

    Description   编号为1到N的N只奶牛正各自驾着车打算在牛德比亚的高速公路上飞驰.高速公路有M(1≤M≤N)条车道.奶牛i有一个自己的车速上限Si(l≤Si≤1,000,000).     ...

  2. Implement Trie (Prefix Tree) 解答

    Question Implement a trie with insert, search, and startsWith methods. Note:You may assume that all ...

  3. oracle获取某一字段字符串长度

    用length方法 select t.* from tp_area t where substr(t.area_id,0,2)='03' and length(t.area_id)>2

  4. [置顶] 教你如何搭建RobotFramework环境

    看到这篇文章的朋友,相信已经知道RobotFramework是干什么的了,我这里就不再赘述了. 搭建步骤: 1. 下载安装Python,下载地址http://www.python.org/getit/ ...

  5. Linux NFS服务器的安装与配置(转载)

    一.NFS服务简介 NFS 是Network File System的缩写,即网络文件系统.一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布.功能是通过网络让不同的机器.不同的操 ...

  6. C# StreamReader/StreamWriter与FileStream用法详解

    http://www.360doc.com/content/13/0610/08/12579422_291878973.shtml

  7. 分享一个BUG

    这段时间在做改版的时候,遇上一个非常莫名其妙的bug,最终是被我的一个后端同事给发现和指正的.这个bug就是,一个js方法在ie7和ie8下面报 SCRIPT:1010 缺少标示符的错误.这个错误我百 ...

  8. nat网络穿透整理笔记(思维导图)

    mindmanger整理的,关于Nat穿透,图片太小,可以点击放大,单独看图片.

  9. FFmpeg详解

    认识FFMPEG FFMPEG堪称自由软件中最完备的一套多媒体支持库,它几乎实现了所有当下常见的数据封装格式.多媒体传输协议以及音视频编解码器.因此,对于从事多媒体技术开发的工程师来说,深入研究FFM ...

  10. 分享一个自己写的基于JQuery的一个Web背景切换的Demo

    这个效果主要有两个特点: 1. 背景切换的渐变 2. 背景大小自适应 3. 背景自适应保持比例同时, 相对居中 js源码: (function ($) { $.fn.bgChange = functi ...