Sql Server 视图数据的增删改查教程
作者:一碗面 发布时间:2024-01-22 07:51:05
一、视图的基本概念
视图是用于查询的另外一种方式。 与实际的表不同,它是一个虚表;因此数据库中只存在视图的定义,而不存在视图中相对应的数据,数据仍然存放在原来的基本表中。视图是一种逻辑对象。
二、 视图能做什么
导出数据; 在导出数据时,常常需要多个表联合查询,这个时候就可以使用视图;转换字段,如把status(0/1 Int类型)字段转换成启用/停用(文字) ,然后用视图保存定义。
数据安全,可以给视图加密。
三、视图操作
3.1 查询数据
(一)准备素材:
使用两张表,其中一张是家电表,另外一张字典表(只需要知道这两张表有一个连接字段brandID-RowID:注意两个表没有强制使用外键约束),准备好素材
SELECT TOP 1000 [appliancesName]
,[appliancesType]
,[code]
,[**brandId**]
,[standard]
,[appliancesStatus]
,[appliancesIsNew]
,[appliancesIsKey]
,[appliancesRemark]
,[appliancesId]
FROM sfa_t_appliances
另外一张表字典表
SELECT TOP 1000 [**RowID**]
,[PRowID]
,[DicKey]
,[DicVal]
,[Status]
FROM sfa_t_TSysDictionary
说明:sfa_t_appliances 表中的字段brandId 与 sfa_t_TSysDictionary表中的rowid做关联。
(二)创建视图:
create view appliances_view(id,name,brandName)
as
select s.appliancesId,s.appliancesName,d.DicVal
from sfa_t_appliances s,sfa_t_TSysDictionary d
where s.brandId = d.RowID
(三)查询:
查询数据,可以将视图看做一张实实在在的数据表,能够执行各种查询操作。
如下图所示,执行一个查询操作:
(四)备注
有些书上说:可以对任何查询结果进行排序,但是只有当视图包括Top子句时才能排序视图。这样看来书上确实是有问题的。动手实践出真知
3.2 插入数据
实验一
往视图中插入一条数据:
解释:
往视图中插入数据时,能够往sfa_t_appliances 中插入数据。但是视图为什么读取不到呢?
create view appliances_view(id,name,brandName)
as
select s.appliancesId,s.appliancesName,d.DicVal
from sfa_t_appliances s,sfa_t_TSysDictionary d
where s.brandId = d.RowID
注意视图的创建语法:是通过关联关系获取到的数据。注意观看视图的三个字段的来源。自然,在appliancesID为112233的记录中没有brandID,所以自然不能读取到数据。
实验二
说明: 往只含一个基本字段中插入数据是完全没有问题的。上图也插入成功了。
实验三
将多个基表的字段都插入试试:
insert into appliances_view(id,name,brandName) values(112234,'视图','冰箱')
小节:
使用INSERT语句进行插入操作的视图必须能够在基表(组成视图查询的表)中插入数据,否则会操作失败。
如果视图上没有包括基表中所有属性为not null的行,那么插入操作会由于哪些列的NULL值而失败。
补充
通过视图可以向数据库表中插入数据,修改数据和删除表中数据。如果视图的SELECT语句中包含了DISTINCT、表达式(如计算列和函数),或FROM子句中引用多个表,或者引用不可更新的视图,或有Group by 或者having子句,那么都不能通过视图操作数据。
3.3 修改数据
解释
能够对数据进行修改,但是只能修改一张表中的数据。
查看下图,修改基于两个表的字段:
失败了,说明只能修改一张表中的字段。
3.4 删除数据
小结:
如果一个视图链接了两个以上的基表,则不允许进行数据删除操作。如果视图中的列是常数或者几个字符串列值得和,那么尽管插入和更新操作时不允许的,但是却可以进行删除操作。
实验:
(一) 创建基于一个表的视图:
(二)执行删除操作结果:
(三)结果说明:
基于一个表的视图是能够执行删除操作的。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。
来源:https://uzong.blog.csdn.net/article/details/77954476


猜你喜欢
- 本文实例讲述了Python走楼梯问题解决方法。分享给大家供大家参考,具体如下:# -*- coding:utf-8 -*-#!python3
- 问题:开发中常使用Navicat查询数据库,并修改数据库中的值。今天发现查询结果为只读,不能修改。一般连表查不能修改我是知道的,但是单表查居
- 目录一、索引类型1.B+树2.MyISAM和InnoDB的B+树索引实现方式的区别(聚簇索引和非聚簇索引)?3.非聚簇索引4.聚簇索引的优缺
- 本文实例为大家分享了JavaScript实现淘宝网图片的局部放大的具体代码,供大家参考,具体内容如下要实现的效果如下:<!DOCTYP
- Windows•安装lxml最好的安装方式是通过wheel文件来安装,http://www.lfd.uci.edu/~gohlke/pyth
- 本文实例讲述了python实现爬取千万淘宝商品的方法。分享给大家供大家参考。具体实现方法如下:import timeimport level
- 一、前言经过前面的两篇文章,整体工作已经完成了2/3了,剩下的1/3,将会在本片文章提及前面两步文章链接python实战之德州扑克第一步-发
- python中bool数组取反操作由于Python中使用数字0,1 代表Flase,Ture 。所以bool数组不能像matlab一样直接进
- 1. 创建一个图import networkx as nxg = nx.Graph()g.clear() #将图上元素清空所有的构建复杂网络
- 如下所示:Traceback (most recent call last):File "<stdin>",
- 不管何时何地,只要我们编程时遇到了跟时间有关的问题,都要想到 datetime 和 time 标准库模块,今天我们就用它内部的方法,详解py
- python,pycharm的环境变量设置官网下载安装python解释器时,如果忘记勾选添加到环境变量[add to path],可进行如下
- 本文为大家分享了php运行环境搭建安装图文教程,供大家参考,具体内容如下安装apache:1,不要安装到有中文的目录中:2,尽量将apach
- 写在前面周日下午在家学习,看到一个关于切片的问题,在网上找了一些资料,做个总结。上代码func main() {sl := make([]i
- 目录1、系统环境,必要知识2、安装python3.6.53、安装Django4、安装uWSGI5、安装nginx6、MySQL安装配置7、编
- 前言在两种python循环语句的使用中,不仅仅是循环条件达到才能跳出循环体。所以,在对python函数进行阐述之前,先对跳出循环的简单语句块
- 1.数组和切片有什么区别Go语言中数组是固定长度的,不能动态扩容,在编译期就会确定大小,声明方式如下:var buffer [255]int
- 我们使用alter table add column语句向现有表中添加新列。简介alter table table_nameadd [col
- 因为工作需求,需要审核一部分query内容是否有效,query储存在Excel中,文本内容为页面的Title,而页面的URL以HyperLi
- 一、安装1、安装git Windows 客户端—GitHub Desktop具有git功能的Windows客户端软件有很