SQL sever中的视图

目录

一、视图概述:

二、视图好处

三、创建视图

法一:

法二:

四、查看视图信息

五、视图插入数据

六、视图修改数据

七、视图删除数据

八、删除视图

法一:

法二:


一、视图概述:

    视图是一种常用的数据库对象,它将查询的结果以虚拟表的形式存储在数据中。视图并不在数据库中以存储数据集的形式存在。视图的结构和内容是建立在对表的查询基础之上的,和表一样包括行和列,这些行列数据都来源于其所引用的表,并且是在引用视图过程中动态生成的。
视图中的内容是由查询定义来的,并且视图和查询都是通过SQL语句定义的,它们有着许多相同和不同之处,具体如下。

  • ☑存储:视图存储为数据库设计的一部分,而查询则不是。视图可以禁止所有用户访问数据库中的基表,而要求用户只能通过视图操作数据。这种方法可以保护用户和应用程序不受某些数据库修改的影响,同样也可以保护数据表的安全性。
  • ☑排序:可以排序任何查询结果,但是只有当视图包括TOP子句时才能排序视图。

总之,视图是由一个或多个表(或其他视图)派生的虚拟表。视图是基于查询结果集的命名查询,它包含了从一个或多个表中选择的特定列和行。因此视图可以被认为是一种虚拟表,其内容并不实际存储在数据库中,而是在查询时动态生成。通过创建视图,我们可以隐藏底层表的复杂性,简化复杂查询,并提供一种方便和安全的方式来访问数据。视图只是定义了一个查询,并根据查询的结果生成数据。

视图为数据呈现提供了多样的表现形式,用户可以通过它浏览表中感兴趣的数据。在SQL Server
2008中视图分为以下3类。

  • ☑标准视图:保存在数据库中的SELECT查询语句,即通常意义上理解的视图。
  • ☑索引视图:创建有索引的视图称为索引视图。它经过计算并存储有自己的数据,可以提高某些类型查询的性能,尤其适用于聚合许多行的查询,但不太适用于经常更新的基本数据集。
  • ☑分区视图:是在一台或多台服务器间水平联结一组表中的分区数据,以使数据看上去来源于一个表。

二、视图好处

使用视图的好处包括:

  • 简化复杂的查询:视图可以根据具体的业务需求和逻辑将复杂的查询操作进行封装,提供更简洁易懂的查询语句。
  • 提高性能:视图可以对查询结果进行缓存,当查询相同的数据时,可以减少查询时间和数据库负载。
  • 数据安全性:通过视图,可以控制用户对数据的访问权限,限制他们只能查看和操作特定的列或行,从而保护数据的安全性。

三、创建视图

法一:

使用SQL Server Management Studio创建视图 ,具体操作步骤如下:

(1)启动SQL Server Management Studio,并连接到SQL Server2008中的数据库。

(2)在“对象资源浏览器”中展开“数据库”节点,展开指定的数据库,比如我选择的是SJCX。

(3)右击“视图”选项,在弹出的快捷菜单中选择“新建视图”命令,如图所示。

(4)打开“添加表”对话框,如图所示。在列表框中选择表rank,单击“添
加”按钮,然后单击“关闭”按钮关闭该对话框。

(5)进入视图设计器界面,如图所示。在“表选择区”中选择“所有列”选项,单击执行按
钮,视图结果区中自动显示视图结果。

(6)单击工具栏中的“保存”按钮口,弹出“选择名称”对话框,如图所示。在“输入视图名称”文本框中输入视图名称View_Rank,单击“确定”按钮即可保存该视图。 

法二:

使用 CREATE VIEW 语句,具体语法如下:

CREATE VIEW view_name AS
SELECT column1, column2, ...
FROM table(s)
WHERE condition;

 比如选择数据库SJCX,创建视图View_people,则SQL语句为:

CREATE VIEW view_people AS
SELECT [DepartmentId],[RankId],[PeopleId],[PeopleName],[PeopleGender],[PeopleBirth],[PeopleSalary],[PeoplePhone],[PeopleAddress],[peopleAddTime],[PeopleMail]FROM [SJCX].[dbo].[People];

执行该SQL语句后即创建成功。这是最常用的创建视图的方法,使用 CREATE VIEW 语句指定视图的名称(view_name),然后在 SELECT 子句中定义视图所选择的列和表(或其他视图),并可以包含一个可选的 WHERE 子句来筛选数据。

四、查看视图信息

下面在SQL Server Management Studio中查看视图View Stu的信息,具体操作步骤如下。

(1)启动SQL Server Management Studio,并连接到SQL Server2008中的数据库。

(2)在“对象资源浏览器”中展开“数据库”节点,展开指定的数据库SJCX。

(3)再依次展开“视图”节点,就会显示出当前数据库中的所有视图,右击要查看信息的视图。

(4)在弹出的快捷菜单中,如果想要查看视图的属性,选择“属性”选项,弹出“视图属性”对话框,如图所示:

(5)如果想要查看视图中的内容,可在图所示的快捷菜单中选择“编辑前200行”选项,在右侧即可显示视图中的内容。

(6)如果想要重新设置视图,可在快捷菜单中选择“设计”选项,打开视图的设计界面,如图所示。在此界面中可对视图重新进行设置。

        

五、视图插入数据

使用视图可以插入新的记录,但应该注意的是,新插入的数据实际上是存储在与视图相关的表中。
示例:
向视图View_Rank中插入信息“4,顶级”。
步骤如下:
(1)右击要插入记录的视图,在弹出的快捷菜单中选择“设计”命令,显示视图的设计界面。
(2)在显示视图结果的最下面一行直接输入新记录即可,如图所示。


(3)然后按下Enter键,即可把信息插入到视图中。

(4)单击!按钮,完成新记录的添加,如图所示:

六、视图修改数据

使用视图可以修改数据记录,但是与插入记录相同,修改的是数据表中的数据记录。
示例:
修改视图View_Rank中的记录,将“顶级”修改为“低级”。
步骤如下:
(1)右击要修改记录的视图,在弹出的快捷菜单中选择“设计”命令,显示视图的设计界面。
(2)在显示的视图结果中,选择要修改的内容,直接修改即可。
(3)最后按下Enter键,即可把信息保存到视图中。 

七、视图删除数据

使用视图可以删除数据记录,但是与插入记录相同,删除的是数据表中的数据记录。
示例:
删除视图View_Rank中的记录“低级”。
步骤如下:
(1)右击要删除记录的视图,在弹出的快捷菜单中选择“设计”命令,显示视图的设计界面。
(2)在显示视图的结果中,右击要删除的行“低级”,在弹出的快捷菜单中选择“删除”命令,弹出“删除”对话框,如图所示。


(3)单击“是”按钮,便可将该记录删除。 

(4)检查结果,如图所示:

八、删除视图

对于数据库中不需要的视图可以将其删除,以释放存储空间。可以使用企业管理器将其删除,也
可以使用SQL语句将其删除。

法一:

使用企业管理器删除视图的步骤如下:
(1)启动SQL Server Management Studio,.并连接到SQL Server2008中的数据库。
(2)在“对象资源管理器”中依次展开“数据库”指定的数据库/“视图”节点。
(3)右击要删除的视图,在弹出的快捷菜单中选择“删除”命令,弹出“删除对象”对话框,如图所示。 在“删除对象”对话框中,单击“显示依赖关系”按钮,可以显示与该视图有关的数据表和视图,单击“确定”按钮,便可将该视图删除。

注意:
在删除之前,应该先查看视图的依赖关系,如果有对象依赖于要删除的视图,那么要确
定是否要保存该对象,如果不保存,则可以直接将该视图删除,否则将不能删除该视图。

法二:

使用 DROP VIEW 语句来删除视图。下面是删除视图的语法:

DROP VIEW [IF EXISTS] view_name;--或者
IF OBJECT_ID('view_name', 'V') IS NOT NULLDROP VIEW view_name;

可选的 IF EXISTS 子句用于检查视图是否存在。如果视图不存在,执行语句时不会引发错误。

使用 OBJECT_ID 函数检查视图是否存在(V 表示视图),如果存在则执行 DROP VIEW 语句进行删除。

注意:

从 SQL Server 2016 版本开始,引入了 DROP VIEW IF EXISTS 语法。因此,如果使用的是 SQL Server 2016 及其更高版本,可以直接使用该语法来删除视图。

示例:

删除视图view_people:

-- 删除视图
DROP VIEW view_people;-- 删除视图(如果存在)
DROP VIEW IF EXISTS view_people;--或者
IF OBJECT_ID('view_people', 'V') IS NOT NULLDROP VIEW view_people;

  

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

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

相关文章

K8S云计算系列-(4)

K8s Dashboard UI 部署实操 Kubernetes实现的最重要的工作是对Docker容器集群统一的管理和调度,通常使用命令行来操作Kubernetes集群及各个节点,命令行操作非常不方便,如果使用UI界面来可视化操作,会更加方便的管理和维护。如下为…

苹果上架常见问题-appstore开发者名称修改

转载:appstore开发者名称修改 在App Store中,开发者名称是一个非常关键的信息,它决定了用户对应用的信任度和对开发者的认知程度。开发者名称也是一个非常重要的推广工具,一个好的开发者名称可以帮助开发者吸引更多的用户关注。因…

基于统计学库statsmodel实现时间序列预测

文章目录 1.数据探索与清洗2.假设检验:平稳性检验3.差分处理4.绘制ACF与PACF图像,完成模型选择4.建立ARIMA和SARIMA模型5.解读summary6.确定最终的模型 ARIMA模型在统计学上的三大基本假设: 时间序列具有平稳性(stationary&#x…

后厂村路灯在线签名网站,在线签名工具,IPA在线签名

IPA在线签名工具网站,在线实现IPA包签名 案例网站:在线签名 - 后厂村路灯https://sign.vx365.vip/ 用户可以自定义签名网站样式。 用户可以独立部署到自己服务器,使用自己的域名。 用户可以使用自己服务器,加快签名速度&#xf…

clickhouse数据库简介,列式存储

clickhouse数据库简介 1、关于列存储 所说的行式存储和列式存储,指的是底层的存储形式,数据在磁盘上的真实存储,至于暴漏在上层的用户的使用是没有区别的,看到的都是一行一行的表格。 idnameuser_id1闪光10266032轨道物流10265…

Zilliz X Dify.AI ,快速打造知识库 AI 应用

Zilliz 大模型生态矩阵再迎新伙伴!近日,Zilliz 和 Dify.AI 达成合作,Zilliz 旗下的产品 Zilliz Cloud、Milvus 与开源 LLMOps 平台 Dify 社区版进行了深度集成。 01.Zilliz Cloud v.s. Dify Dify 作为开源的 LLMs App 技术栈,在此…

LeetCode-94-二叉树的中序遍历

题目描述&#xff1a; 题目链接&#xff1a;LeetCode-94-二叉树的中序遍历 解题思路&#xff1a;递归&#xff0c;具体可以参考 LeetCode-144-二叉树的前序遍历 代码实现&#xff1a; class Solution {List<Integer> listnew ArrayList<>();public List<Integer…

C# 将音频PCM数据封装成wav文件

文章目录 前言一、如何实现&#xff1f;1.定义头结构2.预留头部空间3.写入PCM数据4.写入头部信息 二、完整代码三、使用示例总结 前言 之前实现了《C 将音频PCM数据封装成wav文件》&#xff0c;最近将其改成了C#版本。使用C#实现录音功能时还是需要写wav文件的&#xff0c;直接…

FPGA project : flash_secter_erase

flash的指定扇区擦除实验。 先发写指令&#xff0c;再进入写锁存周期等待500ns&#xff0c;进入写扇区擦除指令&#xff0c;然后写扇区地址&#xff0c;页地址&#xff0c;字节地址。即可完成扇区擦除。 模块框图&#xff1a; 时序图&#xff1a; 代码&#xff1a; module…

部署zabbix代理服务器、部署zabbix高可用集群

目录 部署zabbix代理服务器 1、环境设置 2、设置 zabbix 的下载源&#xff0c;安装 zabbix-proxy 3、配置Mariadb yum源&#xff0c;并下载marisdb数据库 4.、启动数据库&#xff0c;并初始化数据库 5、登录数据库&#xff0c;创建数据库并指定字符集&#xff0c;并进行…

面试复盘(待删)

泛型的理解 官方文档里是这么写的 In languages like C# and Java, one of the main tools in the toolbox for creating reusable components is generics, that is, being able to create a component that can work over a variety of types rather than a single one. Thi…

WSL VScode连接文件后无法修改(修改报错)

权限问题 usrname:用户名 dirpath:要修改的文件夹路径 sudo chown -R usrname /dirpath

【配置vscode编写c或c++程序,并在外部控制台输出程序和解决中文乱码问题!!!】

配置vscode编写c或c程序&#xff0c;并在外部控制台输出程序和解决中文乱码问题&#xff01;&#xff01;&#xff01; 1、点击扩展&#xff0c;添加C语言所需的插件&#xff08;点击安装&#xff0c;安装完成后点击设置标志安装另一个版本&#xff0c;注意一定要安装1.8.4版本…

计算机视觉(Computer Vision, CV)是什么?

什么是计算机视觉 近年来&#xff0c;计算机视觉 (Computer Vision&#xff0c;简称CV) 不断普及&#xff0c;已成为人工智能 (AI) 增长最快的领域之一。计算机视觉致力于使计算机能够识别和理解图像和视频中的物体和人。 计算机视觉应用程序使用来自传感设备、人工智能、机器…

ffmpeg中AVCodecContext和AVCodec的关系分析

怎么理解AVCodecContext和AVCodec的关系 AVCodecContext和AVCodec是FFmpeg库中两个相关的结构体&#xff0c;它们在音视频编解码中扮演着不同的角色。 AVCodecContext&#xff1a;是编解码器上下文结构体&#xff0c;用于存储音视频编解码器的参数和状态信息。它包含了进行音视…

hive 知识总结

​编辑 社区公告教程下载分享问答JD 登 录 注册 01 hive 介绍与安装 1 hive介绍与原理分析 Hive是一个基于Hadoop的开源数据仓库工具&#xff0c;用于存储和处理海量结构化数据。它是Facebook 2008年8月开源的一个数据仓库框架&#xff0c;提供了类似于SQL语法的HQL&#xf…

考古:MFC界面的自适应缩放(代码示例)

MFC窗体的控件的自适应缩放早期VS开发环境是不支持的&#xff0c;后来VS开发环境提供了支持但也简单&#xff0c;或者固定的缩放比例不符合要求。我一向坚持一个理念&#xff1a;“不支持缩放的窗口不是好窗口”&#xff0c;所以需要有一个自定义的缩放处理。机制不复杂&#x…

2023年中国渔业研究报告

第一章 行业概况 1.1 定义 渔业&#xff0c;作为全球经济的重要支柱之一&#xff0c;其核心活动包括捕捞、水产养殖、产品加工与销售等。其不仅是食物安全的重要保障&#xff0c;还是许多沿海和内陆地区经济发展的重要动力。 首先&#xff0c;捕捞活动是渔业的基础。通过海洋…

以太坊 CALL 数据解析【ETH】

文章目录 前言代码前言 当我们通过 jsonrpc CALL 获取到数据时,不可读,怎么办? 这里直接给大家一个工具类 代码 package trace// author JavaPub shiyuwangimport ("encoding/json""fmt""io/ioutil""net/http""strings&qu…

Web后端开发登录校验及JWT令牌,过滤器,拦截器详解

如果用户名正确则成功进入 登录功能 代码 Controller Service Mapper 结果 若登录成功结果如下: 如果登录失败,结果如下 登录校验 为什么需要登录校验 有时再未登录情况下, 我们也可以直接访问部门管理, 员工管理等功能 因此我们需要一个登录校验操作, 只有确认用户登录…