关系数据库标准语言SQL(数据更新、空值的处理、试图【例子详解】)

本文主要是介绍关系数据库标准语言SQL(数据更新、空值的处理、试图【例子详解】),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、数据更新

1.插入数据

1.1插入元组

两种插入数据方式

  • 插入元组
  • 插入子查询结果
    • 可以一次插入多个元组

语句格式
INSERT
INTO <表名> [(<属性列1>[,<属性列2 >…)]
VALUES (<常量1> [,<常量2>]… );

功能

  • 将新元组插入指定表中

INTO子句

  • 指定要插入数据的表名及属性列
  • 属性列的顺序可与表定义中的顺序不一致
  • 没有指定属性列:表示要插入的是一条完整的元组,且属性列属性与表定义中的顺序一致
  • 指定部分属性列:插入的元组在其余属性列上取空值

VALUES子句

  • 提供的值必须与INTO子句匹配

  • 值的个数

  • 值的类型

     [例1]将一个新学生元组(学号:201215128;姓名:陈冬;性别:男;所在系:IS;年龄:18岁)插入到Student表中。INSERTINTO  Student (Sno,Sname,Ssex,Sdept,Sage)VALUES ('201215128','陈冬','男','IS',18);[例2] 插入一条选课记录( '200215128','1 ')。INSERTINTO SC(Sno,Cno)VALUES ('201215128 ',' 1 ');关系数据库管理系统将在新插入记录的Grade列上自动地赋空值。或者:INSERTINTO SCVALUES (' 201215128 ',' 1 ',NULL);
    

1.2插入子查询结果

语句格式
INSERT
INTO <表名> [(<属性列1> [,<属性列2>… )]
子查询;

  • INTO子句
  • 子查询
    • SELECT子句目标列必须与INTO子句匹配

      • 值的个数
      • 值的类型

      [例3] 对每一个系,求学生的平均年龄,并把结果存入数据库
      第一步:建表
      CREATE TABLE Dept_age
      ( Sdept CHAR(15) /系名/
      Avg_age SMALLINT); /学生平均年龄/
      第二步:插入数据
      INSERT
      INTO Dept_age(Sdept,Avg_age)
      SELECT Sdept,AVG(Sage)
      FROM Student
      GROUP BY Sdept;

关系数据库管理系统在执行插入语句时会检查所插元组是否破坏表上已定义的完整性规则

  • 实体完整性
  • 参照完整性
  • 用户定义的完整性
    • NOT NULL约束
    • UNIQUE约束
    • 值域约束

2.修改数据

语句格式
UPDATE <表名>
SET <列名>=<表达式>[,<列名>=<表达式>]…
[WHERE <条件>];

功能

  • 修改指定表中满足WHERE子句条件的元组
  • SET子句给出<表达式>的值用于取代相应的属性列
  • 如果省略WHERE子句,表示要修改表中的所有元

三种修改方式

  • 修改某一个元组的值

       [例4  将学生201215121的年龄改为22岁UPDATE  StudentSET Sage=22WHERE  Sno=' 201215121 '; 
    
  • 修改多个元组的值

         [例5]  将所有学生的年龄增加1岁。UPDATE StudentSET Sage= Sage+1;
    
  • 带子查询的修改语句

      [例6]  将计算机科学系全体学生的成绩置零。UPDATE SCSET     Grade=0WHERE Sno  IN(SELETE SnoFROM     StudentWHERE  Sdept= 'CS' );
    

关系数据库管理系统在执行修改语句时会检查修改操作是否破坏表上已定义的完整性规则

  • 实体完整性
  • 主码不允许修改
  • 用户定义的完整性
    • NOT NULL约束
    • UNIQUE约束
    • 值域约束

3.删除数据

语句格式
DELETE
FROM <表名>
**[WHERE <条件>];

功能**

  • 删除指定表中满足WHERE子句条件的元组

WHERE子句

  • 指定要删除的元组
  • 缺省表示要删除表中的全部元组,表的定义仍在字典中

三种删除方式

  • 删除某一个元组的值

       [例7]  删除学号为201215128的学生记录。DELETEFROM StudentWHERE Sno= 201215128 ';
    
  • 删除多个元组的值

        [例8]  删除所有的学生选课记录。DELETEFROM SC;
    
  • 带子查询的删除语句

         [例9]  删除计算机科学系所有学生的选课记录。DELETEFROM  SCWHERE  Sno  IN(SELETE  SnoFROM   StudentWHERE  Sdept= 'CS') ;
    

二、空值的处理

空值就是“不知道”或“不存在”或“无意义”的值。

一般有以下几种情况:

  • 该属性应该有一个值,但目前不知道它的具体值
  • 该属性不应该有值
  • 由于某种原因不便于填写

1.空值的产生

空值是一个很特殊的值,含有不确定性。对关系运算带来特殊的问题,需要做特殊的处理。

空值的产生

	[例10]向SC表中插入一个元组,学生号是”201215126”,课程号是”1”,成绩为空。INSERT INTO SC(Sno,Cno,Grade)VALUES('201215126 ','1',NULL);   /*该学生还没有考试成绩,取空值*/或INSERT INTO SC(Sno,Cno)VALUES(' 201215126 ','1');             /*没有赋值的属性,其值为空值*/[例11]  将Student表中学生号为”201215200”的学生所属的系改为空值。UPDATE StudentSET Sdept = NULLWHERE Sno='201215200';

2.空值的判断

判断一个属性的值是否为空值,用IS NULL或IS NOT NULL来表示。

	[例 12]  从Student表中找出漏填了数据的学生信息SELECT  *FROM StudentWHERE Sname IS NULL OR Ssex IS NULL OR Sage IS NULL OR Sdept IS NULL;

3. 空值的约束条件

属性定义(或者域定义)中

  • 有NOT NULL约束条件的不能取空值
  • 加了UNIQUE限制的属性不能取空值
  • 码属性不能取空值

4. 空值的算术运算、比较运算和逻辑运算

  • 空值与另一个值(包括另一个空值)的算术运算的结果为空值
  • 空值与另一个值(包括另一个空值)的比较运算的结果为UNKNOWN
  • 有UNKNOWN后,传统二值(TRUE,FALSE)逻辑就扩展成了三值逻辑

逻辑运算符真值表:(T表示TRUE,F表示FALSE,U表示UNKNOWN)
在这里插入图片描述

	[例13]  找出选修1号课程的不及格的学生。SELECT SnoFROM SCWHERE Grade < 60 AND Cno='1';查询结果不包括缺考的学生,因为他们的Grade值为null。

三、视图

视图的特点

  • 虚表,是从一个或几个基本表(或视图)导出的表
  • 只存放视图的定义,不存放视图对应的数据
  • 基表中的数据发生变化,从视图中查询出的数据也随之改变

1.定义视图

1.1建立视图

语句格式
CREATE VIEW
<视图名> [(<列名> [,<列名>]…)]
AS <子查询>
[WITH CHECK OPTION];

WITH CHECK OPTION

  • 对视图进行UPDATE,INSERT和DELETE操作时要保证更新、插入或删除的行满足视图定义中的谓词条件(即子查询中的条件表达式)

子查询可以是任意的SELECT语句,是否可以含有ORDER BY子句和DISTINCT短语,则决定具体系统的实现。

组成视图的属性列名:全部省略或全部指定

  • 全部省略:
    • 由子查询中SELECT目标列中的诸字段组成
  • 明确指定视图的所有列名:
    • 某个目标列是聚集函数或列表达式
    • 多表连接时选出了几个同名列作为视图的字段
    • 需要在视图中为某个列启用新的更合适的名字

关系数据库管理系统执行CREATE VIEW语句时只是把视图定义存入数据字典,并不执行其中的SELECT语句。

在对视图查询时,按视图的定义从基本表中将数据查出。

	[例14]  建立信息系学生的视图。CREATE VIEW IS_StudentAS SELECT Sno,Sname,SageFROM     StudentWHERE  Sdept= 'IS';[例15]建立信息系学生的视图,并要求进行修改和插入操作时仍需保证该视图只有信息系的学生 。CREATE VIEW IS_StudentAS SELECT Sno,Sname,SageFROM  StudentWHERE  Sdept= 'IS'WITH CHECK OPTION;

定义IS_Student视图时加上了WITH CHECK OPTION子句,对该视图进行插入、修改和删除操作时,RDBMS会自动加上Sdept='IS’的条件。

若一个视图是从单个基本表导出的,并且只是去掉了基本表的某些行和某些列,但保留了主码,我们称这类视图为行列子集视图。

  • IS_Student视图就是一个行列子集视图。

基于多个基表的视图

	[例16]  建立信息系选修了1号课程的学生的视图(包括学号、姓名、成绩)。CREATE VIEW IS_S1(Sno,Sname,Grade)AS SELECT Student.Sno,Sname,GradeFROM  Student,SCWHERE  Sdept= 'IS' ANDStudent.Sno=SC.Sno ANDSC.Cno= '1';

基于视图的视图

		[例17]  建立信息系选修了1号课程且成绩在90分以上的学生的视图。CREATE VIEW IS_S2ASSELECT Sno,Sname,GradeFROM  IS_S1WHERE  Grade>=90;

带表达式的视图

	[例18]  定义一个反映学生出生年份的视图。CREATE  VIEW BT_S(Sno,Sname,Sbirth)AS SELECT Sno,Sname,2014-SageFROM  Student;

分组视图

	[例19]  将学生的学号及平均成绩定义为一个视图CREAT  VIEW S_G(Sno,Gavg)AS  SELECT Sno,AVG(Grade)FROM  SCGROUP BY Sno;[例20]将Student表中所有女生记录定义为一个视图CREATE VIEW F_Student(F_Sno,name,sex,age,dept)ASSELECT  *                        /*没有不指定属性列*/FROM  StudentWHERE Ssex=‘女’;**缺点:**
修改基表Student的结构后,Student表与F_Student视图  的映象关系被破坏,导致该视图不能正确工作。

1.2删除视图

语句的格式:
DROP VIEW <视图名>[CASCADE];

  • 该语句从数据字典中删除指定的视图定义

  • 如果该视图上还导出了其他视图,使用CASCADE级联删除语句,把该视图和由它导出的所有视图一起删除

  • 删除基表时,由该基表导出的所有视图定义都必须显式地使用DROP VIEW语句删除

      [例21 ] 删除视图BT_S和IS_S1DROP VIEW BT_S;	/*成功执行*/DROP VIEW IS_S1;	/*拒绝执行*/要删除IS_S1,需使用级联删除:DROP VIEW IS_S1 CASCADE; 
    

2.查询视图

用户角度:查询视图与查询基本表相同

关系数据库管理系统实现视图查询的方法

  • 视图消解法(View Resolution)
    • 进行有效性检查

    • 转换成等价的对基本表的查询

    • 执行修正后的查询

      [例22] 在信息系学生的视图中找出年龄小于20岁的学生。
      SELECT Sno,Sage
      FROM IS_Student
      WHERE Sage<20;

      视图消解转换后的查询语句为:
      SELECT Sno,Sage
      FROM Student
      WHERE Sdept= ‘IS’ AND Sage<20;

      [例23] 查询选修了1号课程的信息系学生
      SELECT IS_Student.Sno,Sname
      FROM IS_Student,SC
      WHERE IS_Student.Sno =SC.Sno AND SC.Cno= ‘1’;

3.更新视图

	[例24]  将信息系学生视图IS_Student中学号”201215122”的学生姓名改为”刘辰”。UPDATE  IS_StudentSET  Sname= '刘辰'WHERE  Sno= ' 201215122 ';转换后的语句:UPDATE  StudentSET Sname= '刘辰'WHERE Sno= ' 201215122 ' AND Sdept= 'IS';[例25]删除信息系学生视图IS_Student中学号为”201215129”的记录 DELETEFROM IS_StudentWHERE Sno= ' 201215129 ';转换为对基本表的更新:DELETEFROM StudentWHERE Sno= ' 201215129 ' AND Sdept= 'IS';

更新视图的限制:一些视图是不可更新的,因为对这些视图的更新不能唯一地有意义地转换成对相应基本表的更新

	例[26]定义的视图S_G为不可更新视图。UPDATE  S_GSET          Gavg=90WHERE  Sno= '201215121';

这个对视图的更新无法转换成对基本表SC的更新

DB2对视图更新的限制:

  • 若视图是由两个以上基本表导出的,则此视图不允许更新。

  • 若视图的字段来自字段表达式或常数,则不允许对此视图执行INSERT和UPDATE操作,但允许执行DELETE操作。

  • 若视图的字段来自集函数,则此视图不允许更新。

  • 若视图定义中含有GROUP BY子句,则此视图不允许更新。

  • 若视图定义中含有DISTINCT短语,则此视图不允许更新。

  • 若视图定义中有嵌套查询,并且内层查询的FROM子句中涉及的表也
    是导出该视图的基本表,则此视图不允许更新。

     例:将SC中成绩在平均成绩之上的元组定义成一个视图CREATE VIEW GOOD_SCAS SELECT  Sno,Cno,GradeFROM     SCWHERE Grade >(SELECT AVG(Grade)FROM     SC);一个不允许更新的视图上定义的视图也不允许更新
    

4.视图的作用

  • 视图能够简化用户的操作
  • 视图使用户能以多种角度看待同一数据
  • 视图对重构数据库提供了一定程度的逻辑独立性
  • 视图能够对机密数据提供安全保护
  • 适当的利用视图可以更清晰的表达查询

视图能够简化用户的操作
当视图中数据不是直接来自基本表时,定义视图能够简化用户的操作

  • 基于多张表连接形成的视图
  • 基于复杂嵌套查询的视图
  • 含导出属性的视图

视图使用户能以多种角度看待同一数据

  • 视图机制能使不同用户以不同方式看待同一数据,适应数据库共享的需要
    视图对重构数据库提供了一定程度的逻辑独立性

  • 数据库重构 :

     例:学生关系Student(Sno,Sname,Ssex,Sage,Sdept) “垂直”地分成两个基本表:SX(Sno,Sname,Sage)        SY(Sno,Ssex,Sdept)
    
  • 视图对重构数据库提供了一定程度的逻辑独立性(续)

    • 视图只能在一定程度上提供数据的逻辑独立性
      • 由于对视图的更新是有条件的,因此应用程序中修改数据的语句可能仍会因基本表结构的改变而改变。
  • 视图能够对机密数据提供安全保护

    • 对不同用户定义不同视图,使每个用户只能看到他有权看到的数据

适当的利用视图可以更清晰的表达查询

  • 经常需要执行这样的查询“对每个同学找出他获得最高成绩的课程号”。可以先定义一个视图,求出每个同学获得的最高成绩

     	 CREATE VIEW VMGRADEASSELECT Sno, MAX(Grade)  MgradeFROM  SCGROUP BY Sno;
    

然后用如下的查询语句完成查询:

	     SELECT SC.Sno,CnoFROM SC,VMGRADE WHERE SC.Sno=VMGRADE.Sno AND       SC.Grade=VMGRADE .Mgrade; 

这篇关于关系数据库标准语言SQL(数据更新、空值的处理、试图【例子详解】)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/568633

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd