实验六七 SQL的数据更新

2024-02-14 17:59

本文主要是介绍实验六七 SQL的数据更新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实验六 SQL的数据更新

实验时间:2课时

实验性质:验证

实验主要内容及方法: SQL数据的插入、修改和删除

实验要求:

(1) 掌握SQL数据插入、修改和删除语句的一般格式。;

(2) 掌握SQL数据插入、修改和删除使用方法。

实验目的:熟练掌握SQL数据插入、修改和删除的使用。

实验设备:装有SQL SERVER 2005的电脑

实验步骤:

(1) 新建一个SQL查询窗口;

(2) 选择数据库;

(3) 验证如下例题:

一、插入数据

例3.52  在数据库SC中先创建一个关系(表)History_Student,其模式(结构)与Students完全一样。

CREATE TABLE History_Student(

Sno char(10) primary key,

Sname char(20) UNIQUE,

Ssex char(2),

Sage int,

Sdept char(20))

试将关系Students中的所有元组插入到关系History_Student中去,其SQL命令为:

INSERT
INTO History_Student
SELECT *
FROM Students;

 

 

二、修改数据

例3.53  将学号为“S03”的学生年龄改为22岁,即要修改满足条件的一个元组的属性值。

 

UPDATE Students
SET Sage=22
WHERE Sno='S03';

例3.54 将所有学生的年龄增加1岁。即要修改多个元组的值。

UPDATE Students
SET Sage=1+Sage;

例3.55  将数学系所有学生的成绩置零。

由于学生所在系的信息在Students表中,而学习成绩在Reports表中,因此,可以将SELECT子查询作为WHERE子句的条件表达式。故该更新要求的SQL命令为:

UPDATE Reports
SET Grade=0
WHERE '数学'=
(SELECT Sdept
FROM Students
WHERE Students.Sno=Reports.Sno);

 

 

三、删除数据

例3.56  分别删除学号为“S04”的学生记录及学生选课记录。(注意参照关系及被参照关系,即参照完整性


 

DELETE
FROM Reports
WHERE  Sno='S04';DELETE
FROM Students
WHERE  Sno='S04';

 

 

例3.57  删除数学系所有学生的选课记录。

 

DELETE
FROM Reports
WHERE '数学'=
(SELECT Sdept
FROM Students
WHERE Students.Sno=Reports.Sno);

 

例3.58  删除所有学生的选课记录。

DELETE
FROM Reports;

 

 

实验七 SQL的视图

实验时间:2课时

实验性质:验证

实验主要内容及方法:SQL视图建立、修改和删除

实验要求:

(1) 掌握SQL视图建立、修改和删除;

(2) 掌握SQL视图查询。

实验目的:熟练掌握SQL的应用。

实验设备:装有SQL Server 2005的电脑

实验步骤:

(1) 选择数据库SC;

(2) 新建查询;

(3) 验证如下例题:

一、定义视图

1 建立视图

例3.59 建立数学系学生的视图Math_Student,并要求进行修改和插入操作时仍需保证该视图只有数学系的学生,视图的属性名为Sno,Sname,Sage,Sdept。

CREATE VIEW Math_Student
AS
SELECT Sno, Sname, Sage, Sdept
FROM Students
WHERE Sdept='数学'
WITH CHECK OPTION

 

例3.60  建立学生的学号(Sno)、姓名(Sname)、选修课程名(Cname)及成绩(Grade)的视图Student_CR。

本视图由三个基本表的连接操作导出,其SQL语句如下:

CREATE VIEW Student_CR
AS
SELECT Students.Sno, Sname, Cname, Grade
FROM Students, Reports, Courses
WHERE Students.Sno=  Reports.Sno

 

 

例3.61  定义一个反映学生出生年份的视图Student_Birth。

CREATE VIEW Student_birth(Sno, Sname, Sbirth)
AS SELECT Sno, Sname, 1996-Sage
FROM Students

 

2 删除视图

DROP VIEW Student_Birth;

例3.62删除视图Student_Birth。

DROP VIEW Student_Birth;

二、查询视图

例3.63 在数学系的学生视图Math_Student中找出年龄(Sage)小于20岁的学生姓名(Sname)和年龄(Sage)。

 

SELECT Sname, Sage
FROM Math_Student
WHERE Sage<20;

说明:本例转换后的查询语句为:

SELECT Sname, Sage

FROM Students

WHERE Sdept=’数学’ AND Sage<20;

例3.64 在Student_CR视图中查询成绩在85分以上的学生学号(Sno)、姓名(Sname)和课程名称(Cname)。

SELECT Sno, Sname, Cname
FROM Student_CR
WHERE Grade>85;

 

 

三、更新视图

例3.65  将数学系学生视图Math_Student中学号为S05的学生姓名改为“黄海”。

UPDATE Math_Student
SET Sname='黄海'
WHERE Sno='S05';

说明:DBMS自动转换为对基本表的更新语句如下:

UPDATE Students

SET Sname='黄海'

WHERE Sno='S05' AND Sdept='数学';

例3.66  向数学系学生视图Math_Student中插入一个新的学生记录,其中学号为“S19”,姓名为“王海”,年龄为20岁。

INSERT
INTO Math_Student
VALUES ('S19', '王海', 20, '数学');

例3.67  删除数学系学生视图Math_Student中学号为“S09”的记录。

DELETE
FROM Math_Student
WHERE Sno='S09'

 

这篇关于实验六七 SQL的数据更新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

MySQL中的交叉连接、自然连接和内连接查询详解

《MySQL中的交叉连接、自然连接和内连接查询详解》:本文主要介绍MySQL中的交叉连接、自然连接和内连接查询,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、引入二、交php叉连接(cross join)三、自然连接(naturalandroid join)四

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA

Mysql表如何按照日期字段的年月分区

《Mysql表如何按照日期字段的年月分区》:本文主要介绍Mysql表如何按照日期字段的年月分区的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、创键表时直接设置分区二、已有表分区1、分区的前置条件2、分区操作三、验证四、注意总结一、创键表时直接设置分区