<%@ page contentType="text/html; charset=gb2312"%> sqlserver实用经验技巧集[三]
网站公告:   ◆北天JAVA技术网热情为java爱好者服务,本网内容包括JAVA(JSP、servlet、EJB、webservice、j2ee、javabean、应用服务器、JavaScript),数据库(MYSQL、SQL Server、Sybase、Oracle、DB2、数据库综合知识),设计研究(设计模式、Struts、Spring、Hibernate、设计框架、设计综合知识),WEB2.0新技术(主要介绍AJAX),以及各种技术的入门、实例、例子等等,欢迎各位多来坐坐!◆  诚邀各位JAVA爱好者加盟!◆  本网站内容丰富,更新快,保证每周20篇以上!  
加入收藏
设为首页
联系站长
承接项目
  相关资源:网站首页 | 免费培训学院 | 技术论坛 | JAVA聊天室 | 作家专栏 | 开发工具 | 认证考试 | 会员俱乐部
  JAVA技术初学者园地 | jsp与servlet | javascript | Java源代码 | EJB | web service | 应用服务器 | JAVA综合知识
  设计研究设计模式 | 设计框架 | Struts | Spring | Hibernate | 开源项目 | 面向对象设计 | 设计综合知识
  数 据 库MYSQL | SQL Server | Sybase | Oracle | DB2 | Informix | Access | 数据库综合知识
  其他资源:AJAX新技术 | 网站开发 | ERP软件 | OA办公软件 | 商业智能BI | 开发综合知识 | 承接项目 | 项目试用

 
 
sqlserver实用经验技巧集[三]
     发布者: 发布时间:2006-05-07
维护sql server中表的索引

  在使用和创建数据库索引中经常会碰到一些问题,在这里可以采用一些另类的方法解决…

    --第一步:查看是否需要维护,查看扫描密度/scan density是否为100%

  declare @table_id int
  set @table_id=object_id(''表名'')
  dbcc showcontig(@table_id)

  --第二步:重构表索引
  dbcc dbreindex(''表名'',pk_索引名,100)

  --重做第一步,如发现扫描密度/scan density还是小于100%则重构表的所有索引
  --杨铮:并不一定能达100%。
  dbcc dbreindex(''表名'','''',100)

  sql server补丁安装常见问题
  谁碰到问题就看看咯:)

  一、补丁安装过程中常见问题

  如果在安装补丁的时候遇到如下类似错误:

  1、安装过程中出现“以前进行的程序创建了挂起的文件操作,运行安装程序前,必须重新启动”,请按照下面步骤解决:

  a、重启机器,再进行安装,如果发现还有该错误,请按下面步骤
  b、在开始->运行中输入regedit
  c、到hkey_local_machine\system\currentcontrolset\control\session manager 位置
  d、选择文件->倒出,保存
  e、在右边窗口右击pendingfilerenameoperations,选择删除,然后确认
  f、重启安装,问题解决

  如果还有同样问题,请检查其它注册表中是否有该值存在,如有请删掉。


  2、在安装sql server sp3,有时候会出现:无论用windows认证还是混和认证,都出现密码错误的情况,这时查看临时目录下的sqlsp.out,会发现以下描述:
  [tcp/ip sockets]specified sql server not found.
  [tcp/ip sockets]connectionopen (connect()).
  其实这是sql server sp3的一个小bug,在安装sp3的时候,没有监听tcp/ip端口,可以按照以下步骤进行:

  1、打开sql server客户器网络实用工具和服务器网络工具,确保启用的协议中包含name pipe,并且位置在第一位.

    2、确保[hkey_local_machine\software\microsoft\mssqlserver\client\connectto]
  "dsquery"="dbnetlib".
  如果没有,请自己建立
  3、停止mssql.
  4、进行安装.

  这样就可以进行正确安装了。

  二、sql server补丁版本的检查

  sql server的补丁版本检查不如windows 补丁版本检查直接,一个系统管理员,如果不了解sql server版本对应的补丁号,可能也会遇到一点麻烦,因此在这说明一下,通过这样的办法判别机器是安全的办法,不会对系统产生任何影响。

  1、用isql或者sql查询分析器登录到sql server,如果是用isql,请在cmd窗口输入isql -u sa,然后输入密码,进入;如果是用sql查询分析器,请从程序中启动,输入sa和密码(也可以用windows验证)。

  2、在isql中输入:
  select @@version;
  go

  或者sql查询分析器中输入(其实如果不想输入,只要打开帮助的关于就可以了:))
  select @@version;
  然后按执行;
  这时会返回sql的版本信息,如下:
  microsoft sql server 2000 - 8.00.760 (intel x86) dec 17 2002 14:22:05 copyright (c) 1988-2003 microsoft corporation enterprise edition on windows nt 5.0 (build 2195: service pack 3)

  其中的8.00.760就是sql server的版本和补丁号。对应关系如下:

  8.00.194 -——————sql server 2000 rtm
  8.00.384 -——————(sp1)
  8.00.534 -——————(sp2)
  8.00.760 -——————(sp3)

  这样我们就能看到sql server的正确版本和补丁号了。

  我们也可以用xp_msver看到更详细的信息

  sql server数据库的备份和恢复措施
  最常用的操作,新手们看看……

    一、备份数据库

  1、打开sql企业管理器,在控制台根目录中依次点开microsoft sql server
  2、sql server组-->双击打开你的服务器-->双击打开数据库目录
  3、选择你的数据库名称(如论坛数据库forum)-->然后点上面菜单中的工具-->选择备份数据库
  4、备份选项选择完全备份,目的中的备份到如果原来有路径和名称则选中名称点删除,然后点添加,如果原来没有路径和名称则直接选择添加,接着指定路径和文件名,指定后点确定返回备份窗口,接着点确定进行备份

  二、还原数据库

  1、打开sql企业管理器,在控制台根目录中依次点开microsoft sql server

  2、sql server组-->双击打开你的服务器-->点图标栏的新建数据库图标,新建数据库的名字自行取

  3、点击新建好的数据库名称(如论坛数据库forum)-->然后点上面菜单中的工具-->选择恢复数据库

  4、在弹出来的窗口中的还原选项中选择从设备-->点选择设备-->点添加-->然后选择你的备份文件名-->添加后点确定返回,这时候设备栏应该出现您刚才选择的数据库备份文件名,备份号默认为1(如果您对同一个文件做过多次备份,可以点击备份号旁边的查看内容,在复选框中选择最新的一次备份后点确定)-->然后点击上方常规旁边的选项按钮

  5、在出现的窗口中选择在现有数据库上强制还原,以及在恢复完成状态中选择使数据库可以继续运行但无法还原其它事务日志的选项。在窗口的中间部位的将数据库文件还原为这里要按照你sql的安装进行设置(也可以指定自己的目录),逻辑文件名不需要改动,移至物理文件名要根据你所恢复的机器情况做改动,如您的sql数据库装在d:\program files\microsoft sql server\mssql\data,那么就按照您恢复机器的目录进行相关改动改动,并且最后的文件名最好改成您当前的数据库名(如原来是bbs_data.mdf,现在的数据库是forum,就改成forum_data.mdf),日志和数据文件都要按照这样的方式做相关的改动(日志的文件名是*_log.ldf结尾的),这里的恢复目录您可以自由设置,前提是该目录必须存在(如您可以指定d:\sqldata\bbs_data.mdf或者d:\sqldata\bbs_log.ldf),否则恢复将报错

  6、修改完成后,点击下面的确定进行恢复,这时会出现一个进度条,提示恢复的进度,恢复完成后系统会自动提示成功,如中间提示报错,请记录下相关的错误内容并询问对sql操作比较熟悉的人员,一般的错误无非是目录错误或者文件名重复或者文件名错误或者空间不够或者数据库正在使用中的错误,数据库正在使用的错误您可以尝试关闭所有关于sql窗口然后重新打开进行恢复操作,如果还提示正在使用的错误可以将sql服务停止然后重起看看,至于上述其它的错误一般都能按照错误内容做相应改动后即可恢复

  三、收缩数据库

  一般情况下,sql数据库的收缩并不能很大程度上减小数据库大小,其主要作用是收缩日志大小,应当定期进行此操作以免数据库日志过大。

    1、设置数据库模式为简单模式:打开sql企业管理器,在控制台根目录中依次点开microsoft sql server-->sql server组-->双击打开你的服务器-->双击打开数据库目录-->选择你的数据库名称(如论坛数据库forum)-->然后点击右键选择属性-->选择选项-->在故障还原的模式中选择“简单”,然后按确定保存
  2、在当前数据库上点右键,看所有任务中的收缩数据库,一般里面的默认设置不用调整,直接点确定
  3、收缩数据库完成后,建议将您的数据库属性重新设置为标准模式,操作方法同第一点,因为日志在一些异常情况下往往是恢复数据库的重要依据。

  四、设定每日自动备份数据库

  强烈建议有条件的用户进行此操作!

  1、打开企业管理器,在控制台根目录中依次点开microsoft sql server-->sql server组-->双击打开你的服务器

  2、然后点上面菜单中的工具-->选择数据库维护计划器

  3、下一步选择要进行自动备份的数据-->下一步更新数据优化信息,这里一般不用做选择-->下一步检查数据完整性,也一般不选择

  4、下一步指定数据库维护计划,默认的是1周备份一次,点击更改选择每天备份后点确定

  5、下一步指定备份的磁盘目录,选择指定目录,如您可以在d盘新建一个目录如:d:\databak,然后在这里选择使用此目录,如果您的数据库比较多最好选择为每个数据库建立子目录,然后选择删除早于多少天前的备份,一般设定4-7天,这看您的具体备份要求,备份文件扩展名一般都是bak就用默认的
  6、下一步指定事务日志备份计划,看您的需要做选择-->下一步要生成的报表,一般不做选择-->下一步维护计划历史记录,最好用默认的选项-->下一步完成

  7、完成后系统很可能会提示sql server agent服务未启动,先点确定完成计划设定,然后找到桌面最右边状态栏中的sql绿色图标,双击点开,在服务中选择sql server agent,然后点击运行箭头,选上下方的当启动os时自动启动服务

  8、这个时候数据库计划已经成功的运行了,他将按照您上面的设置进行自动备份

  修改计划:

  1、打开企业管理器,在控制台根目录中依次点开microsoft sql server-->sql server组-->双击打开你的服务器-->管理-->数据库维护计划-->打开后可看到你设定的计划,可以进行修改或者删除操作

  五、数据的转移(新建数据库或转移服务器)

  一般情况下,最好使用备份和还原操作来进行转移数据,在特殊情况下,可以用导入导出的方式进行转移,这里介绍的就是导入导出方式,导入导出方式转移数据一个作用就是可以在收缩数据库无效的情况下用来减小(收缩)数据库的大小,本操作默认为您对sql的操作有一定的了解,如果对其中的部分操作不理解,可以咨询动网相关人员或者查询网上资料

  1、将原数据库的所有表、存储过程导出成一个sql文件,导出的时候注意在选项中选择编写索引脚本和编写主键、外键、默认值和检查约束脚本选项

  2、新建数据库,对新建数据库执行第一步中所建立的sql文件

  3、用sql的导入导出方式,对新数据库导入原数据库中的所有表内容

 


(转载文章请保留出处:北天JAVA技术网(www.java114.com))
 
更多精彩文章:
mssqlserver2000数据转换服务部署
sqlserver2000分布式查询:oledb连接
配置sqlserver2000选项
sqlserver性能优化
一次简单的sqlserver的安全测试(1)
一次简单的sqlserver的安全测试(2)
 
最近评论:
        
冰封的往事!
wow power leveling,wow gold,wow power leveling,wow gold max(5063)
        
冰封的往事!
wow power leveling,wow gold,WoW Gold,wow gold max(2403)
        
飞舞的传奇!
传世私服,传世私服.传奇世界私服传奇世界私服,传世私服传世私服, 传奇世界私服传奇世界私服.传奇私服传奇私服. max(4497)
        
标 题:   
内 容:   
 
                                  
 
免责声明:该文章由网友发表,如果对您造成侵权,请联系站长

首页 - 承接项目 - 网站地图 - 联系我们 -
版权所有北天JAVA技术工作室 ICP证号:粤ICP备06079815号