SqlServer基础语法(三)
1.数据库备份的方法:
完整数据库备份GPOSDB 文件大小:23MB 日志备份 GPOSDB日志备份文件大小:211KB
--完整备份
Backup DATABASE GPOSDB
To disk='D:\GPOSDB_backup_201207160152.bak'
--还原
restore database 数据库 from disk='c:\abc.bak' WITH replace
2.收缩数据库的大小的方法
数据文件:建立聚集索引,或者重建索引,然后shrinkfile 收缩数据文件
日志文件:数据库恢复模式不能是简单要大容量日志或者完整 ,
定期备份事务日志,才能截断事务日志 3.设置数据库自动增长注意要点
-1要设置成按固定大小增长,而不能按比例 对于小的数据库,设置一次增长50MB到100MB,大的数据库,一次增长100MB到200MB
--2要定期监测各个数据文件的使用情况,尽量保证每个文件剩余的空间一样大或者是期望的比例
--3设置文件最大值
--4发生增长后,要及时检查文件空间分配情况,避免SQL总是往个别文件写数据 4.模仿灾难发生时还原adventurework数据库 示例 stopat
--模仿灾难发生时还原adventurework数据库 示例 stopat BACKUP DATABASE AdventureWorks
TO DISK= 'D:\MSSQL\Databackup\AdventureWorks.bak' BACKUP LOG AdventureWorks
TO DISK ='D:\MSSQL\Databackup\AdventureWorks.trn'
GO
--灾难发生后,试图创建一个尾日志备份
BACKUP LOG AdventureWorks
TO DISK='D:\MSSQL\Databackup\AdventureWorkstail.trn'
WITH norecovery;
GO
--------------------------------------
--用界面的话这两步一起完成
--从备份恢复一个全备份
RESTORE DATABASE AdventureWorks
FROM DISK ='D:\MSSQL\Databackup\AdventureWorks.bak'
WITH FILE=1,NORECOVERY --从备份中恢复一个正常的日志备份
RESTORE LOG AdventureWorks
FROM DISK ='D:\MSSQL\Databackup\AdventureWorks.trn'
WITH NORECOVERY; -------------------------------------------------------------- --用stopat 恢复尾日志备份
RESTORE LOG AdventureWorks
FROM DISK='D:\MSSQL\Databackup\AdventureWorkstail.trn'
WITH STOPAT='2012 20:59:00',
RECOVERY;
GO
5.检查日志文件不能被截断的原因
--检查日志文件不能被截断的原因
SELECT * FROM sys.databases WHERE database_id=9
--SELECT * FROM sys.sysdatabases
--查看日志占用日志文件占用率
DBCC SQLPERF(LOGSPACE)
GO --查看不能截断日志文件的原因
SELECT name,recovery_model_desc,log_reuse_wait,log_reuse_wait_desc
FROM sys.databases
GO --检查最老的活动事务
DBCC OPENTRAN
GO
SELECT st.text,t2.* FROM sys.dm_exec_sessions AS t2,sys.dm_exec_connections AS t1
CROSS APPLY sys.dm_exec_sql_text(t1.most_recent_sql_handle) AS st
WHERE t1.session_id=t2.session_id
AND t1.session_id>50 --如果事务比较久,可以用kill命令杀掉进程
KILL 54
6.检测孤立用户并恢复孤立用户到新的服务器 解决数据库镜像孤立用户问题
1 --检测孤立用户并恢复孤立用户到新的服务器 解决数据库镜像孤立用户问题
2 --注意:重新链接只能链接SQL登录帐号,不能链接Windows登录帐号
3 --如果不选择重新链接可以使用备份master数据库的方法还原到新的服务器上,可以避免一个数据库有
4 --成千上百个数据库用户的情况
5 SELECT * FROM sys.server_principals
6 SELECT * FROM sys.database_principals
7
8 --检测孤立用户
9 USE GPOSDB --要建立镜像的数据库
10 EXEC sys.sp_change_users_login @Action = 'report', -- varchar(10)
11 @UserNamePattern = NULL, -- sysname
12 @LoginName = NULL, -- sysname
13 @Password = NULL -- sysname
14 GO
15
16 --在服务器新建一个同名的登录帐号 ,例如hengshan,然后重新链接hengshan服务器登录帐户与数据库用户hengshan,将
17 --他们的SID改成一致的
18 USE GPOSDB
19 GO
20 EXEC sys.sp_change_users_login @Action = 'update_one', -- varchar(10)
21 @UserNamePattern = 'hengshan', -- sysname<database_user>
22 @LoginName = 'hengshan', -- sysname<login_name>
23 @Password = 'test' -- sysname 将数据库用户密码跟登录帐号密码都设置为test 这里主库的hengshan用户的密码也是test
24
25
26
27 ---------------SQL2008 AUTO_FIX才有用----------------------------------------------
28
29 USE GPOSDB
30 EXEC sys.sp_change_users_login @Action = 'AUTO_FIX', -- varchar(10)
31 @UserNamePattern =hengshan -- sysname
32
33
34 ------------------------解决数据库镜像孤立用户问题---------------------
35 --在主数据库中执行如下语句:
36 USE master;
37 select sid,name from syslogins;
38
39
40 --查找出相应的数据库用户名和sid,例如:上述的’myuser’
41 --
42 --在备数据库中执行如下语句:
43
44 USE master;
45 exec sp_addlogin
46 @loginame = 'myuser',
47 @passwd = 'test',
48 @sid = 0x074477739DCA0E499C29394FFFC4ADE4
49
50 --这里的’LoginName’即主数据库中的登录名,sid即是上述通过SQL语句查找出的sid。
51 --注意一下密码
52
53 --到此为止可以认为备机数据库的环境已经与主机同步了,还差数据库内的数据未同步
SqlServer基础语法(三)的更多相关文章
- Python 基础语法(三)
Python 基础语法(三) --------------------------------------------接 Python 基础语法(二)------------------------- ...
- 从零开始学 Web 之 ES6(五)ES6基础语法三
大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...
- SqlServer基础语法
历史 有很多软件公司开发了数据库产品,其中微软公司的数据库产品命名为 SQL Server,也称 MS SQL Server. 1989年 Ashton-Tate/Microsoft SQL Serv ...
- Java基础语法(三)---数组
一.概念 同一种类型数据的集合.简单的来说就是一容器,用来装东西的. 使用数组的好处:可以自动给数组中的元素从0开始编号,方便操作这些元素. 二.一维数组的格式 格式1:元素类型 [ ...
- css基础语法三
[]伪类选择器] 1.写法: 伪类选择器,在选择器后面,用:分隔,紧接伪类状态: eg : .a:link 2. 超链接的伪类状态: :link - 未访问状态 :visited - 已访问状态 :h ...
- SqlServer基础语法(二)
先看一下腰实现的功能:
- CSS基础语法(三) CSS的6种特性
样式表常用写法及特性(组合.继承.关联性.权值性.层叠性.重要性) 1.样式的组合:把具有相同声明定义的选择符组合在一起,并用逗号隔开.-例如:段落元素p.单元格元素td和类c1可以使用相同样式: p ...
- Python 1基础语法三(变量和标识符的区别)
一.字面量: 就是一个一个的值,如1.2.3.‘world’,就是它自己本身表达的字面值.字面意思,在程序中可以直接使用. 二.变量(variable): 可以用来保存字面量,变量本身没有任何意思:如 ...
- HTML 网页开发、CSS 基础语法——三. HTML概念
1.纯文本格式 纯文本格式,就是没有任何文本修饰的,没有任何粗体,下划线,斜体,图形,符号,或者特殊字符,及特殊打印格式的文本,只保存文本,不保存其格式设置. ①格式对比 纯文本格式 富文本格式 最常 ...
随机推荐
- python---自定义字段验证
各个字段类,含正则和验证方法 #字段类 class IPField: REGULAR = "^(25[0-5]|2[0-4]\d|[0-1]?\d?\d)(\.(25[0-5]|2[0-4] ...
- idea工具常见问题汇总
1.隐藏idea创建项目自带的文件及文件夹比如.iml和.idea文件夹 Settings→Editor→File Types 在下方的忽略文件和目录(Ignore files and folders ...
- Dubbo的负载均衡
背景 Dubbo是一个分布式服务框架,能避免单点故障和支持服务的横向扩容.一个服务通常会部署多个实例.如何从多个服务 Provider 组成的集群中挑选出一个进行调用,就涉及到一个负载均衡的策略. 几 ...
- Neural Networks and Deep Learning 课程笔记(第二周)神经网络的编程基础 (Basics of Neural Network programming)
总结 一.处理数据 1.1 向量化(vectorization) (height, width, 3) ===> 展开shape为(heigh*width*3, m)的向量 1.2 特征归一化( ...
- android get或post及HttpClient与服务器数据交互
1.Service package mydemo.mycom.demo2.service; import org.apache.http.HttpResponse; import org.apache ...
- postman变量的使用和设置
之前只是使用postman做接口管理——将各个项目使用到的接口分类管理起来,用的时候手动改参数调用.这次项目连着跑三个接口,需要用到前一个接口的参数,还来回切平台,真的很麻烦,所以就搜了一下有什么便利 ...
- 【tomcat】Web环境(tomcat)下新增一个访问路径(虚拟路径)
在tomcat上配置图片虚拟目录,在tomcat下conf/server.xml中添加:(在server.xml最好不要添加中文注释,在有些操作系统会启动失败) <Context docBase ...
- 改变checkbox的默认样式
针对于CheckBox默认样式的改变,和选中状态的改变 <label class="checkBox"><input type="checkbox&qu ...
- python3之Django多数据库
1.定义数据库 在django项目中, 一个工程中存在多个APP应用很常见:有时候希望不同的APP连接不同的数据库,这个时候需要建立多个数据库连接.在Django的setting中使用DATABASE ...
- 【转】Python数据类型之“集合(Sets)与映射(Mapping)”
[转]Python数据类型之“集合(Sets)与映射(Mapping)” 一.集合类型(Sets) 集合对象是不同的(不可重复)hashable对象的无序集合.常见用法包括:成员关系测试.移除序列中的 ...