再看数据库——(2)视图

概念

*是从用户使用数据库的观点来说的。

*从一个或多个表(视图)中导出来的

*一个虚表,或者说查询表


为什么要用视图呢?

 一是简单,看到的就是需要的。视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。

二是 安全,通过视图用户只能查询和修改他们所能见到的数据,但不能授权到数据库特定行和特定的列上。通过视图,用户可以被限制在数据的不同子集上:使用权限可被限制在另一视图的一个子集上,或是一些视图和基表合并后的子集上。

三是逻辑数据独立性。视图可帮助用户屏蔽真实表结构变化带来的影响。

概括来说,由于用户通过视图只能查询修改他们所能见到数据,所以操作起来自然简单许多,也安全多了。这点在视图的优点处还有涉及。

操作:


创建:

方法一:









执行显示结果:


方法二:

用T-SQL语句:

use niunan
go
create view View_Test1
--要查询的内容--
as select name,title,content,createtime
--查询的表--
from category,news
--查询条件--
where category.id=news.categoryId 

相应的,视图的修改和删除也可直接在对象资源管理器中操作,在这里就不做介绍。

修改:

use niunan
go
--要修改的视图,括号中是列名--
alter view View_Test(name,createTime)
--格式与新建视图时一致
as select name,title
from category,news
where category.id=news.categoryId 


删除:

drop view View_Test


优点:

简化了对表增删改的操作。利用视图,我们可以同时从两个表中查找数据,而不用视图,就要一个一个的查询,很麻烦也容易出错。在一定程度上,使得数据库的复杂度降低,数据共享更为方便。另一方面,用户通过视图只能查看和修改他们所能见到的数据,简化了用户权限的管理。

视图与表:

视图中只存放了表的定义,但没有储存视图对应的数据,这些数据仍放在原来的数据表中。拿上面的例子说,新建的视图中并没有实际的新闻内容、类别名称等数据,它们都还是储存在原有的news,category表中。

视图可以像表一样进行增删改查的操作。


系列博客推荐:

再看数据库——(1)存储过程

再看数据库——(2)视图

再看数据库——(3)触发器


转载于:https://www.cnblogs.com/saixing/p/6730329.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/420795.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

spring bean的创建,生命周期

1. 初探spring 什么是spring Spirng 是分层的Java se/ee应用full-stack(web层mvc dao层jdbc模板 业务事务管理)轻量级开源框架,以IoC(inverse of control :反转和控制) 和 AOP(Aspect Oriented Programming: 面向切面编程&#xf…

1025 反转链表 (25分)

输入样例: 00100 6 4 00000 4 99999 00100 1 12309 68237 6 -1 33218 3 00000 99999 5 68237 12309 2 33218 输出样例: 00000 4 33218 33218 3 12309 12309 2 00100 00100 1 99999 99999 5 68237 68237 6 -1 解题心得: 本题两个注意点&am…

网站如何启用SSL安全证书?IIS7启用新建Https:/

网站使用SSL,通过SSL证书申请,然后导入之后。我们需要对网站进行设置才能正常使用SSL证书,具体如何操作让网站启用SSL呢,本经验以一个网站添加SSL主机头的方式为例来,网站启用SSL服务器安全证书。(如果没有证书的&…

js乱码解决

mmp最近在写项目,引入js文件,f12控制台老给我报红色的错误, 点开,是引入js文件中文乱码。。。反手myeclipse打开js文件,也正常啊,中文没乱码。。。 解决办法 打开js文件,设置为带bom的utf-8编码…

Mapreduce执行过程分析(基于Hadoop2.4)——(一)

1 概述 该瞅瞅MapReduce的内部运行原理了,以前只知道个皮毛,再不搞搞,不然怎么死的都不晓得。下文会以2.4版本中的WordCount这个经典例子作为分析的切入点,一步步来看里面到底是个什么情况。 2 为什么要使用MapReduce Map/Reduce&…

spring配置数据源

spring配置数据源1. 什么是数据源连接池2. 手动创建数据源(c3p0,druid)2.1 导入数据库连接驱动,数据源pom坐标2.2 创建数据源2.3 配置jdbc.properties, 解耦拿到数据源3. spring配置数据源3.1 bean方式创建数据源13.2 bean方式创建…

centos8安装

一. 下载centos centos下载 下载镜像版 mini版本 二,安装centos8 虚拟机安装 可 打开虚拟机安装centos 选择下载的镜像 配置磁盘大小 配置资源 配置虚拟机内存,处理器个数等. 安装成功后,也可配置

一、Insertion sort

1. 问题 2. 算法 2.1 伪代码 2.2 算法思想 2.3 手工演示 2.4 Python实现 《算法导论》一书数组默认从111开始,这种方式适合算法分析,从000开始适合程序实现,为了能和伪代码一致便于对比,后边所有的Python实现中数组均从111开始。…

Hibernate学习笔记

Hibernate是什么: Hibernate 架构: 下载、安装、必要的 jar包、环境CLASSPAST的设置(此步骤省略) Hibernate框架的使用步骤:1、创建Hibernate的配置文件(hibernate.cfg.xml)2、创建持久化类&…

二、Merge sort

1 问题 2 算法 2.1 伪代码 2.2 算法思想 2.3 手工演示 2.4 Python实现 # -*- coding: utf-8 -*- import sysdef merge(A, p, q, r):n1 q - p 1n2 r - qL [0] * (n1 2)R [0] * (n2 2)for i in range(1, n11):L[i] A[pi-1]for j in range(1, n21):R[j] A[qj]L[n11] 6…

三、递归树分析法

1 问题 2 解决思路 使用递归树猜想一个上界,使用归纳法证明上界也是下界。 2.1 使用递归树(recursion tree)猜想结论(不严谨) 使用递归树两点:1⃣️逐行展开;2⃣️逐行相加; 逐行…

html5input表单标签新属性

初探h5一,h5 新增表单类型二,新增表单属性三,code demo一,h5 新增表单类型 •email 邮箱地址•url 网络地址•number 数字框•range 滑块•Date pickers (date, month, week, time, datetime, datetime-local) 日期时间框•search…

关于java的JIT知识

1.JIT的工作原理图 工作原理 当JIT编译启用时(默认是启用的),JVM读入.class文件解释后,将其发给JIT编译器。JIT编译器将字节码编译成本机机器代码。 通常javac将程序源码编译,转换成java字节码,JVM通过解释…

Storage 使用

关于web项目数据存储1. 存储种类2. localStorage/sessionStorage2.1 概念2.2 api的使用3. 学生curd测试localStorage针对客户端存储讲 ——storage1. 存储种类 1. 分为服务器端和客户端的存储 2. 服务器端:1. 内存存储(临时)application session request pageConte…