SQL实验:数据表操作与视图影响分析
需积分: 16 162 浏览量
更新于2024-08-04
收藏 702KB DOCX 举报
在本次数据库实验三中,主要涉及到了SQL语言的基本操作,包括数据的插入、更新和视图的操作。首先,学员被要求利用SQL语句向person、pay和dept这三个表中插入数据,需要注意的是,当插入多行数据时,可以在Values后面使用逗号分隔不同的数据组。例如:
1. 插入操作:通过执行类似 `INSERT INTO person (字段列表) VALUES (值1, 值2, ...), (值3, 值4, ...);` 的命令,逐条添加新的员工信息。
2. 更新特定记录:指定工号为000006的员工的基本工资更新为1850,这可以通过 `UPDATE pay SET basic_salary = 1850 WHERE id = '000006';` 来实现。
3. 更新视图:对于员工视图view_person,学员需要将姓名为罗玮的员工职称改为高级,这需要用到 `UPDATE view_person SET job_title = '高级' WHERE name = '罗玮';`。
4. 向视图插入数据:为了向视图view_person插入新员工信息,学员需要使用 `INSERT INTO view_person (字段列表) VALUES (值1, 值2, ..., NULL, 值n);`,如插入('000010', '柳芸', '女', NULL, '00103')。
在思考部分,涉及到实际业务场景的应用:
- 市场部员工基本工资调整:学员需要模拟业务逻辑,通过 `UPDATE pay SET basic_salary = basic_salary + 200 WHERE dept_id = '市场部';` 来调整。
- 数据完整性问题:删除实发工资低于2500元的员工信息不合理,因为没有考虑时间因素,可能导致误删。同时,由于person表与pay表的关系,删除操作可能会导致数据不一致。
- 参照完整性测试:修改视图的数据确实会影响到person和pay表,因为视图是基于这些基表的。此外,还需要检查数据完整性约束,如性别列应添加列级约束,确保只能输入“男”或“女”。
课外任务中,学员需要创建一个新的表stu,并通过SQL操作与student表交互:
- 插入新数据:使用 `INSERT INTO student (SELECT * FROM stu WHERE student.id NOT IN (stu.id))`,只添加stu表中student表中不存在的记录。
- 更新现有数据:使用 `UPDATE student SET fields = (SELECT fields FROM stu WHERE student.id = stu.id)`,更新表中对应学号的数据。
- 删除课程信息:由于参照完整性,删除“数据结构”课程信息会失败,因为其他课程可能依赖于它。同样,删除“《红楼梦》欣赏”课程会导致sc表中的选课信息不准确,因为课程本身并未真正删除,只是在课程表中不存在了。
总结,本实验主要锻炼了学员对SQL操作的熟练度,包括数据的增删改查,以及对数据完整性约束的理解,同时还涉及到了数据库设计中的参照完整性和业务逻辑应用。通过这些练习,学员能够加深对关系型数据库管理系统的理解,并提升实际操作能力。
2022-06-05 上传
2022-06-08 上传
2021-12-17 上传
2021-12-17 上传
2022-09-29 上传
2021-12-17 上传
2022-06-05 上传
noyake
- 粉丝: 6
- 资源: 42
最新资源
- JHU荣誉单变量微积分课程教案介绍
- Naruto爱好者必备CLI测试应用
- Android应用显示Ignaz-Taschner-Gymnasium取消课程概览
- ASP学生信息档案管理系统毕业设计及完整源码
- Java商城源码解析:酒店管理系统快速开发指南
- 构建可解析文本框:.NET 3.5中实现文本解析与验证
- Java语言打造任天堂红白机模拟器—nes4j解析
- 基于Hadoop和Hive的网络流量分析工具介绍
- Unity实现帝国象棋:从游戏到复刻
- WordPress文档嵌入插件:无需浏览器插件即可上传和显示文档
- Android开源项目精选:优秀项目篇
- 黑色设计商务酷站模板 - 网站构建新选择
- Rollup插件去除JS文件横幅:横扫许可证头
- AngularDart中Hammock服务的使用与REST API集成
- 开源AVR编程器:高效、低成本的微控制器编程解决方案
- Anya Keller 图片组合的开发部署记录