数据库day-08

一、实验名称和性质

删除修改数据

验证 设计

二、实验目的

1.掌握数据操作-- 删除、修改;

三、实验的软硬件环境要求

硬件环境要求:

       PC机(单机)

使用的软件名称、版本号以及模块:

       Windows  10,SQL Server 2019

四、知识准备

1.数据删除的语句格式:

DELETE  [FROM]  表名   [WHERE  字句]

3.据修改格式:

UPDATE 表名  SET  字段名=表达式 [,…]  [WHERE 字句]

五、实验内容

1.数据的修改操作;

2.数据的删除操作;

六、验证性实验

(1)生成实验数据  (表名自己加学号后三位)

SELECT  *  INTO STUDENTAXXX FROM STUDENTXXX

   SELECT  *  INTO SCOREAXXX FROM SCOREXXX WHERE  DEGREE <0

  INSERT  SCOREAXXX    SELECT  *  FROM SCOREXXX

  --注:下面修改和删除数据,在STUDENTAXXXSCOREAXXX中操作

(2)数据的修改删除

1. 把所有人的出生日期中的月份减1

 UPDATE STUDENTAXXX set Sbirthday=DATEADD(MONTH, -1,Sbirthday)

 2. 把陈文文 的出生日期中年加1,班级改为95033

  UPDATE STUDENTAXXX set Sbirthday=DATEADD(year,1,Sbirthday),Class='95033' where Sname='陈文文'

3. 把95033班所有男生的出生日期中的日减1,女生的出生日期中的日加1

 UPDATE STUDENTAXXX set Sbirthday=case ssex when  '男' THEN DATEADD(DAY,-1,Sbirthday)

                                  WHEN '女' THEN  DATEADD(DAY,1,Sbirthday) END 

                                where Class='95033'

4. 把课程号3-105的所有成绩减10

  UPDATE SCOREAXXX SET Degree-=10 WHERE CNO='3-105'

5. 把课程计算机导论的所有成绩加10

      UPDATE SCOREAXXX SET Degree+=10 WHERE CNO=(select cno from Course where Cname='计算机导论')   --子查询

6.  把李君帅的所有成绩减10

    UPDATE SCOREAXXX   SET Degree=Degree- 10 FROM STUDENTAXXX S JOIN SCOREAXXX SC ON SC.Sno=S.Sno WHERE Sname='李君帅'   --连接

7.  把李君帅的计算机导论成绩加10 

  UPDATE SCOREAXXX   SET Degree=Degree+ 10 FROM STUDENTAXXX S JOIN SCOREAXXX SC ON SC.Sno=S.Sno

      join Course C ON SC.CNO=C.CNO WHERE  Sname='李君帅' AND  Cname='计算机导论'

8. 删除学号109课程 3-245的成绩

   delete from  SCOREAXXX WHERE SNO='109' AND CNO='3-245'

9. 删除曾华庆的 数字电路 成绩 

    delete   SCOREAXXX WHERE SNO=(select sno from STUDENTAXXX where sname='曾华庆' ) AND  CNO=(select cno from Course where Cname='数字电路')

10.删除STUDENTAXXX的所有数据

TRUNCATE TABLE  STUDENTAXXX

11.删除SCOREAXXX的所有数据

  delete   SCOREAXXX

12.其他,运行以下语句,观察结果,分别得到什么结论?

--1. SET ANSI_NULLS {ON | OFF}

SET ANSI_NULLS ON  --默认

select  * FROM SCOREXXX WHERE DEGREE <>NULL

select  * FROM SCOREXXX WHERE DEGREE  =NULL

select  * FROM SCOREXXX WHERE DEGREE  is not null

select  * FROM SCOREXXX WHERE DEGREE  is  null

SET ANSI_NULLS OFF

select  * FROM SCOREXXX WHERE DEGREE <>NULL

select  * FROM SCOREXXX WHERE DEGREE  =NULL

select  * FROM SCOREXXX WHERE DEGREE  is not null

select  * FROM SCOREXXX WHERE DEGREE  is  null

SET ANSI_NULLS ON

--2.SET QUOTED_IDENTIFIER { ON | OFF }

SET QUOTED_IDENTIFIER   ON  --默认

SELECT  SNO,'CNO',DEGREE FROM SCOREXXX

SELECT  SNO,"CNO",DEGREE FROM SCOREXXX

SELECT  SNO,[CNO],DEGREE FROM SCOREXXX

SET QUOTED_IDENTIFIER   Off

SELECT  SNO,'CNO',DEGREE FROM SCOREXXX

SELECT  SNO,"CNO",DEGREE FROM SCOREXXX

SELECT  SNO,[CNO],DEGREE FROM SCOREXXX

SET QUOTED_IDENTIFIER   On

--3. top ...   WITH TIES

select top 3  * from SCOREXXX

select top 3  WITH TIES * from SCOREXXX

select top 3  WITH TIES * from SCOREXXX  order by sno

select top 30  percent     * from SCOREXXX  order by sno

select top 30 percent WITH TIES   * from SCOREXXX  order by sno

 

select top 20 percent WITH TIES   * from SCOREXXX  order by sno

--4. ANY, SOME, ALL

SEELCT * FROM SCOREXXX  where Degree  >= all(select degree from SCOREXXX )

SEELCT * FROM SCOREXXX  where Degree  >= all(select degree from SCOREXXX where Degree is not null )

SEELCT * FROM SCOREXXX where Degree  < any(select degree from SCOREXXX where sno =’101’) and sno =’101’

SEELCT * FROM SCOREXXX where Degree  < some(select degree from SCOREXXX where sno =’103’) and sno =’103’

七、设计性实验

1.实验要求

(1)重新生成实验数据STUDENTAXXXSCOREAXXX

(2)删除修改数据(STUDENTAXXXSCOREAXXX中操作,每题一个语句完成)

1. 把陈文文改名为陈文且出生日期中年月日都加1

UPDATE STUDENT023

SET Sname = '陈文',

    Sbirthday = DATEADD(DAY, 1, DATEADD(MONTH, 1, DATEADD(YEAR, 1, Sbirthday)))

WHERE Sname = '陈文文'

2.把学号101所有成绩加10最大不超过100

  UPDATE SCORE023

SET Degree = CASE WHEN Degree + 10 > 100 THEN 100 ELSE Degree + 10 END

WHERE SNO = '101'

3. 把男生所有成绩加10%女生所有成绩加10最大不超过100

   UPDATE SCORE023

SET Degree = CASE

    WHEN Ssex = '男' THEN

        CASE WHEN Degree * 1.1 > 100 THEN 100 ELSE ROUND(Degree * 1.1, 0) END

    ELSE

        CASE WHEN Degree + 10 > 100 THEN 100 ELSE Degree + 10 END

    END

FROM SCORE023 SC

JOIN STUDENT023 ST ON SC.SNO = ST.SNO

 4.把张旭 老师任课所有及格成绩减10最低不小于60

  

UPDATE SCORE023

SET Degree = CASE WHEN Degree - 10 < 60 THEN 60 ELSE Degree - 10 END

WHERE CNO IN (SELECT CNO FROM teacher023 WHERE Tname = '张旭')

AND Degree >= 60

5. 把曾华庆同学 的张旭 老师任课所有及格成绩加10%最大不超过100

   

UPDATE SCORE023

SET Degree = CASE WHEN Degree * 1.1 > 100 THEN 100 ELSE ROUND(Degree * 1.1, 0) END

WHERE SNO = (SELECT SNO FROM STUDENT023 WHERE Sname = '曾华庆')

AND CNO IN (SELECT CNO FROM  teacher023 WHERE Tname =  '张旭')

AND Degree >= 60

6. 删除成为null的成绩

DELETE FROM SCORE023 WHERE Degree IS NULL

7. 删除王芳芳 的操作系统成绩

DELETE FROM SCORE023

WHERE SNO = (SELECT SNO FROM STUDENT023 WHERE Sname = '王芳芳')

AND CNO = (SELECT CNO FROM COURSE023 WHERE Cname = '操作系统')

8.删除曾华庆同学 的张旭 老师任课所有成绩

   

DELETE FROM SCORE023

WHERE SNO = (SELECT SNO FROM STUDENT023 WHERE Sname = '曾华庆')

AND CNO IN (SELECT CNO FROM teacher023 WHERE Tname = '张旭')

9. 删除女生的计算机导论成绩

DELETE SCORE023

FROM SCORE023 SC

JOIN STUDENT023 ST ON SC.SNO = ST.SNO

JOIN COURSE023 C ON SC.CNO = C.CNO

WHERE ST.Ssex = '女' AND C.Cname = '计算机导论'

10.删除本月过生日的男同学信息

DELETE FROM STUDENT023

WHERE Ssex = '男'

AND MONTH(Sbirthday) = MONTH(GETDATE())

2.实验报告要求

通过本实验,我掌握了:

  1. 使用UPDATE语句修改表中的数据
  2. 使用DELETE语句删除表中的数据
  3. 复杂条件更新和删除的实现方法
  4. 多表连接在更新和删除中的应用
  5. 子查询在更新和删除中的应用

遇到的问题:

  1. 日期计算时需要注意边界情况
  2. 百分比计算时需要考虑四舍五入
  3. 多表连接更新时需要注意表之间的关系

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

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

相关文章

JAVA中Spring全局异常处理@ControllerAdvice解析

一、ControllerAdvice基础概念 1. 什么是ControllerAdvice&#xff1f; ControllerAdvice是Spring 3.2引入的注解&#xff0c;用于定义全局控制器增强组件&#xff0c;主要功能包括&#xff1a; 全局异常处理&#xff08;最常用&#xff09;全局数据绑定全局数据预处理 2. …

开放平台架构方案- GraphQL 详细解释

GraphQL 详细解释 GraphQL 是一种用于 API 的查询语言&#xff0c;由 Facebook 开发并开源&#xff0c;旨在提供一种更高效、灵活且强大的数据获取和操作方式。它与传统的 REST API 有显著不同&#xff0c;通过类型系统和灵活的查询能力&#xff0c;解决了 REST 中常见的过度获…

labview项目文件架构

为了使 LabVIEW 项目更具可扩展性和易于维护&#xff0c;合理规划和设计项目文件结构是非常重要的。 以下是一些基于行业经验和最佳实践的建议&#xff1a; 1. ### 文件夹层次划分 将不同的功能模块分开存储在一个清晰的分层目录结构中是一个常见的做法。通常情况下&#xff…

Chrome的插件扩展程序安装目录是什么?在哪个文件夹?

目录 前提 直接复制到浏览器中打开 Mac下Chrome extension 安装路径 最近换了mac pro用起来虽然方便&#xff0c;但是对常用的一些使用方法还是不熟悉。这不为了找到mac上chrome插件的安装路径在哪里&#xff0c;花费了不少时间。我想应用有不少像小编一样刚刚使用mac的小白…

第13讲:图形尺寸与分辨率设置——适配论文版面,打造专业图稿!

目录 📌 为什么这一讲重要? 🎯 一、先认识几个关键词 ✍️ 二、ggsave() 是导出图的标准方法 📐 三、尺寸设置技巧:对齐目标期刊 🔍 找到目标期刊的图形栏宽 📦 四、多个图组合导出(与 patchwork 搭配) 🧪 五、使用 Cairo / ragg 导出高质量图 🎁 六…

2025年- H13-Lc120-189.轮转数组(普通数组)---java版

1.题目描述 2.思路 import java.util.Arrays;public class H189 {public static void main(String[] args) {int[] newArr {1, 2, 3, 4, 5};int[] nums new int[5];System.arraycopy(newArr,0,nums,0,4);System.out.println(Arrays.toString(nums)); } }补充2&#xff1a; 3.…

机器人--相机

教程 畸变和校正 单目和双目标定 单双&#xff0c;rgb-d原理 单目相机 只有一个摄像头的相机。 原理 小孔成像。 缺点 单目相机无法测量物体点的深度信。 因为物体的Z轴坐标系无法测量。 双目相机 有两个摄像头的相机。 用两个单目相机组成的双目相机就可以测量深度信…

Go 语言入门:(一) 环境安装

一、前言 这里不同于其他人的 Go 语言入门&#xff0c;环境安装我向来注重配置&#xff0c;比如依赖包、缓存的默认目录。因为前期不弄好&#xff0c;后面要整理又影响这影响那的&#xff0c;所以就干脆写成文章&#xff0c;方便后期捡起。 二、安装 1. 安装包 https://go.…

笔试专题(十二)

文章目录 主持人调度题解代码 小红的ABC题解代码 不相邻取数题解代码 空调遥控题解代码 主持人调度 题目链接 题解 1. 排序 2. 先按左端点的大小进行排序&#xff0c;保证时间是连续的&#xff0c;如果后一个点的左端点大于等于前一个点的右端点就是和法的&#xff0c;否则…

Ansible 守护 Windows 安全(Ansible Safeguards Windows Security)

Ansible 守护 Windows 安全&#xff1a;自动化基线检查与加固 在当今网络威胁日益严峻的形势下&#xff0c;保障 Windows 系统安全至关重要。Ansible 作为一款强大的自动化运维工具&#xff0c;可通过自动化脚本实现 Windows 安全基线检查和加固&#xff0c;大幅提升运维效率并…

深度解析 MyBatis`@TableField(typeHandler = JacksonTypeHandler.class)`:优雅处理复杂数据存储

一、引言&#xff1a;当Java对象遇见数据库 在现代应用开发中&#xff0c;我们经常面临一个关键问题&#xff1a;如何将复杂的Java对象&#xff08;如Map、List或自定义POJO&#xff09;优雅地存储到关系型数据库中&#xff1f;传统解决方案需要开发者手动进行序列化和反序列化…

【无标题】四色定理研究团队的构建与实施路径——跨学科建模、编程与理论拓展的全流程方案

### **四色定理研究团队的构建与实施路径** **——跨学科建模、编程与理论拓展的全流程方案** --- #### **一、团队构建与核心分工** ##### **1.1 核心角色与技能需求** | **角色** | **职责** | **技能要求** …

SQLMesh增量模型实战指南:时间范围分区

引言 在数据工程领域&#xff0c;处理大规模数据集和高频率数据更新是一项挑战。SQLMesh作为一款强大的数据编排工具&#xff0c;提供了增量模型功能&#xff0c;帮助数据工程师高效地管理和更新数据。本文将详细介绍如何使用SQLMesh创建和管理基于时间范围的增量模型&#xf…

TCP vs UDP:核心区别、握手过程与应用场景(附对比图)

&#x1f310; 引言 在网络通信中&#xff0c;TCP&#xff08;传输控制协议&#xff09;和UDP&#xff08;用户数据报协议&#xff09;是两大核心传输层协议。它们各有优劣&#xff0c;适用于不同场景。本文将用图文对比实战示例&#xff0c;帮你彻底理解两者的区别&#xff0…

STM32F103C8T6信息

STM32F103C8T6 完整参数列表 一、核心参数 内核架构‌ ARM Cortex-M3 32位RISC处理器 最大主频&#xff1a;72 MHz&#xff08;基于APB总线时钟&#xff09; 运算性能&#xff1a;1.25 DMIPS/MHz&#xff08;Dhrystone 2.1基准&#xff09; 总线与存储‌ 总线宽度&#xff…

WPF-遵循MVVM框架创建图表的显示【保姆级】

文章速览 1、技术栈实现步骤1、创建WPF工程项目2、引入框架 Caliburn.Micro、数据可视化库ScottPlot.WPF3、创建文件夹&#xff0c;并创建相应的View & ViewModel4、创建启动类5、将启动类设置为启动项6、编写View7、编写VM8、将VM和View中的图表进行绑定9、备注 示例效果 …

kafka理论学习汇总

基础知识 基本简介 Kafka 是一个分布式流式处理平台&#xff0c;是一种分布式的&#xff0c;基于发布/订阅的消息系统。 Kafka特点&#xff1a; 1. 同时为发布和订阅提供高吞吐量 Kafka 的设计目标是以时间复杂度为 O(1) 的方式提供消息持久化能力&#xff0c;即使对 TB 级以…

【亚马逊云】AWS Wavelength 从理论讲解到实验演练

&#x1faaa; 本文作者&#xff1a;许业宝 ✍️ 作者信息&#xff1a; &#x1f31e; VSTECS 云解决方案架构师 &#xff5c; AWS Ambassador &#xff5c; &#x1faaa; AWS Community Builder | 亚马逊云科技技能云博主 ⭐ 已获六项 AWS 认证 | CKA、CKS认证 &#xff5c; …

ORACLE DATAGUARD遇到GAP增量恢复方式修复RAC环境备机的实践

ORACLE DATAGUARD技术是一个常用的数据保护机制&#xff0c;在DATAGUARD运行过程中&#xff0c;遇到异常导致备机不同步&#xff0c;而主库的归档日志也被清理&#xff0c;此时出现GAP&#xff0c;无法同步&#xff1b;就需要人工处理&#xff1b;对于小型数据库重新全量同步数…

Java24 抗量子加密:后量子时代的安全基石

一、量子计算威胁与 Java 的应对 随着量子计算机的快速发展&#xff0c;传统加密算法面临前所未有的挑战。Shor 算法可在多项式时间内破解 RSA、ECC 等公钥加密体系&#xff0c;而 Grover 算法能将对称加密的暴力破解效率提升至平方根级别。据 NIST 预测&#xff0c;具备实用价…