解析SQL Server 视图、数据库快照_Mysql

简介数据库快照

      数据库快照,正如其名称所示那样,是数据库在某一时间点的视图。是SQL Server在2005之后的版本引入的特性。快照的应用场景比较多,但快照设计最开始的目的是为了报表服务。比如我需要出2011的资产负债表,这需要数据保持在2011年12月31日零点时的状态,则利用快照可以实现这一点。快照还可以和镜像结合来达到读写分离的目的。下面我们来看什么是快照。

什么是快照

    数据库快照是 SQL Server 数据库(源数据库)的只读静态视图。换句话说,快照可以理解为一个只读的数据库。利用快照,可以提供如下好处:

    提供了一个静态的视图来为报表提供服务

    可以利用数据库快照来恢复数据库,相比备份恢复来说,这个速度会大大提高(在下面我会解释为什么)

    和数据库镜像结合使用,提供读写分离

    作为测试环境或数据变更前的备份,比如我要大批导入或删除数据前,或是将数据提供给测试人员进行测试前,做一个快照,如果出现问题,则可以利用快照恢复到快照建立时的状态

SQL Server 视图

什么是视图?

视图是一个虚拟的表,内容源于查询的结果集。只有当视图上建立了索引后,才会具体化。

视图可以筛选和处理数据,而不是直接访问基础表。如:创建一个视图,只展示源表中的几列数据,无需授予用户访问基础表的权限,取而代之的是授予视图访问权限。

为什么用视图?

1、如果是比较复杂的多表联查,可以将这些复杂的语句放在视图中完成,而我们只需要使用简单的语句查询视图即可。

2、保护基础表,敏感列无法被检索出。

3、对视图添加索引,可以提高效率。

创建视图

1、可以使用SSMS工具创建, 视图->新建视图->选表 选列 ->输入名字保存即可。

2、使用T-SQL创建

if exists(select * from sysobjects where name = 'newView') --如果存在删除
  drop view newView
go
create view newView --创建视图
as
select 学号=id,姓名=name,年龄=age from student
go
select * from newView

关于order by

if exists(select * from sysobjects where name = 'newView') --如果存在删除
  drop view newView
go
create view newView --创建视图
as
select top 10 学号=id,姓名=name,年龄=age from student
order by id desc --如果使用order关键字 则必须指定top
go
select * from newView

修改视图

alter view newView
as
select top 20 * from student
order by id desc --如果使用order关键字 则必须指定top
go

更新架构

--刚刚修改的视图用的是 * 查询的是全部列
--此时修改基础表架构
alter table student add mail varchar(20)

--这时源表已经更新架构,但是视图并没有改变 需要调用系统存储过程更新一下
EXEC sp_refreshview studentView
--这时 新的列才会被加进来

更新视图

对视图进行增、删、改操作,其实就是修改源表。但是由于诸多限制(如由多表联查出的视图,只检索出个别字段,但是插入的时候有些源表上的值是非空的就会出问题),一般不修改视图。

所以更新源表即可更新视图。

数据库快照

数据库快照是某一时间点的源数据库的只读静态视图,可以用来恢复数据库。

使用数据库快照必须与源数据库在相同的服务器实例,并且不能对源数据库进行删除、分离、或还原操作。

使用数据库快照

--源表中数据
use webDB
go
select * from student

if exists(select * from sys.databases where name = 'webDB_DBSS')
drop database webDB_DBSS --存在则删除
go
create database webDB_DBSS --创建数据库快照
on
(
  name = webDB,
  filename='d:\webDB_DBSS.ss' --注意后缀.ss
) --如果有多个文件需要一一指出
as snapshot of webDB
go

--修改源数据库数据
use webDB
go
update student set name='伟大' where id = 10 

--查询源数据库数据
select * from student where id = 10 

--查询快照数据
use webDB_DBSS
go
select * from student where id = 10 

 

修改源数据库,快照数据库并未发生改变。

--修改student表架构
alter table webDB.dbo.student add [address] varchar(20)
select * from webDB.dbo.student

--快照中依然没有
select * from webDB_DBSS.dbo.student 

--删除源数据库student表
drop table webDB.dbo.newTable 

--查询数据库快照该表 依然存在
select * from webDB_DBSS.dbo.newTable

从快照恢复数据到快照创建时刻

restore database webDB
from database_snapshot='webDB_DBSS'
go

select * from webDB.dbo.student --修改的值被改回

select * from webDb.dbo.newTable --被删除的表 改回

以上得知:任何创建快照之后的修改数据都将被改回!

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索sql数据库视图
sqlserver 数据库快照、sql server数据库快照、mysql数据库快照、sql server数据库视图、mysql数据库视图,以便于您获取更多的相关知识。

时间: 2024-10-22 15:43:20

解析SQL Server 视图、数据库快照_Mysql的相关文章

SQL Server 2005 数据库快照(database Snapshot)

server|数据|数据库 数据库快照(atabase snapshot)是一个只读的,静态的数据库视图.一个数据库可以有多个数据库快照,每个数据库快照在被显性的删除之前将一直存在.数据库快照将保持和源数据库快照被创建时刻一致,所以可被用来做一些报表.并且由于数据库快照的存在,我们可以很容易的把数据库回复到快照创建时刻. 数据库快照提供了一个把数据库回复到一个特定时间点的有效途径.一个数据库快照将记录从这个数据库快照被创建后已经提交的所有事务,这样你在对数据库进行错误操作后也不会发出"如果上天能

解析SQL Server 2008数据库中的新数据类型

对于关系型数据库来说,表现树状的层次结构始终是一个问题.微软在SQL Server 2005中首次尝试了 解决这个问题,那就是被称之为通用数据表表达式(Common Table Expressions,CTE)的实现方式. 尽管CTE在现有的数据库架构中运行良好,微软找到了一种将此类层次结构作为头等概念来使用的方式 .因此,为了实现这种效果,他们在SQL Server 2008中提出了一种"HierarchId"数据类型 . 在传统的层次结构中,一条记录仅仅储存了一个指向它父记录的引用

SQL SERVER 2005数据库镜像(1)

本文对SQL SERVER 2005数据库镜像进行了教程式的讲解,具体内容包括:介绍.动态.可用性场景.实现和高可用性技术,供大家参考! 概述 数据库镜像是SQL SERVER 2005用于提高数据库可用性的新技术.数据库镜像将事务日志记录直接从一台服务器传输到另一台服务器,并且能够在出现故障时快速转移到备用服务器.可以编写客户端程序自动重定向连接信息,这样一旦出现故障转移就可以自动连接到备用服务器和数据库. 自动进行故障转移并且使数据损失最小化通常包括昂贵的硬件和复杂的软件.但是,数据库镜像可

浅谈SQL Server中的快照

原文:浅谈SQL Server中的快照 简介     数据库快照,正如其名称所示那样,是数据库在某一时间点的视图.是SQL Server在2005之后的版本引入的特性.快照的应用场景比较多,但快照设计最开始的目的是为了报表服务.比如我需要出2011的资产负债表,这需要数据保持在2011年12月31日零点时的状态,则利用快照可以实现这一点.快照还可以和镜像结合来达到读写分离的目的.下面我们来看什么是快照.   什么是快照     数据库快照是 SQL Server 数据库(源数据库)的只读静态视图

深入解析SQL Server并行执行原理及实践(上)

在成熟领先的企业级数据库系统中,并行查询可以说是一大利器,在某些场景下它可以显著地提升查询的相应时间,提升用户体验.如SQL Server.Oracle等, MySQL目前还未实现,而PostgreSQL在2015实现了并行扫描,相信他们也在朝着更健壮的企业级数据库迈进.RDBMS中并行执行的实现方式大抵相同,本文将通过SQL Server为大家详细解析SQL Server并行执行的原理及一些实践.   1准备知识    硬件环境--在深入并行原理前,我们需要一些准备知识,用以后面理解并行.  

SQL SERVER 2008数据库引擎详细介绍_mssql2008

SQL Server 的数据库引擎组件是用于存储.处理数据和保证数据安全的核心服务.数据库引擎提供受控的访问和快速事务处理,以满足企业中要求极高.大量使用数据的应用程序的要求. SQL Server 支持在同一台计算机上最多存在 50 个数据库引擎实例.对于本地安装,必须以管理员身份运行安装程序.如果从远程共享安装 SQL Server,则必须使用对远程共享具有读取和执行权限的域帐户. 高可用性解决方案概述 高可用性解决方案可减少硬件或软件故障造成的影响,保持应用程序的可用性,尽可能地减少用户所

SQL Server转换数据库的排序规则

什么是排序规则? 排序规则指定了表示每个字符的位模式.它还指定了用于排序和比较字符的规则.排序规则具有下面的特征: ◆语言 ◆区分大小写 ◆区分重音 ◆区分假名 要了解服务器当前使用的排序规则,可以在 SQL 查询分析器中运行 sp_helpsort 系统过程. SQL Server 7.0 不支持使用多个排序规则的数据库.因此,在 SQL Server 7.0 中创建的所有数据库均使用默认的排序规则.SQL Server 2000 支持多个排序规则.SQL Server 2000 数据库可使用

如何转换SQL Server 2008数据库到SQL Server 2005

    背景介绍: 公司一套系统使用的是SQL SERVER 2008数据库,突然一天收到邮件,需要将这套系统部署到各个不同地方(海外)的工厂,需要在各个工厂部署该数据库,等我将准备工作做好,整理文档的时 候,坑爹的事情发生了,居然发现有两三个工厂使用的还是SQL SERVER 2005数据库,要命的是这几个工厂没有SQL SERVER 2008的数据库服务器.而其中两个正准备做服务器的迁移升级,但是IBM的存储还没有到,没办法,这么"反人类,阻挡历史进程"的事情就发生了,我以为 这种

《PowerShell V3——SQL Server 2012数据库自动化运维权威指南》导读

前言 PowerShell V3--SQL Server 2012数据库自动化运维权威指南 PowerShell 是微软的新命令行Shell和脚本语言,可以简化微软不同的应用程序和组件之间的自动化过程和整合过程.数据库专业人士可以利用它内置的大量cmdlets或任意可用的.NET 类来操作PowerShell,使数据库任务自动化,简化整合过程,或者探索完成手头工作的新方法. 本书向忙碌的数据库专业人士提供了大量简单易学的实战案例.无论是你是在审核服务器,导出数据,还是部署报表,总有一种方案适合你