MySQL数据库定义与操作语言
文章为作者原创,未经许可,禁止转载。 -Sun Yat-sen University 冯兴伟
实验1.1 数据库定义
(1)实验目的
理解和掌握数据库DDL语言,能够熟练地使用SQL DDL语句创建、修改和删除数据库、模式和基本表。
(2)实验内容和要求
理解和掌握SQL DDL语句的语法,特别是各种参数的具体含义和使用方法;使用SQL语句创建、修改和删除数据库、模式和基本表。掌握SQL语句常见语法错误的调试方法。
(3)实验重点和难点
实验重点:创建数据库、基本表。
实验难点:创建基本表时,为不同的列选择合适的数据类型,正确创建表级和列级完整性约束,如列值是否允许为空、主码和外码等。注意:数据完整性约束,可以在创建基本表时定义,也可以先创建表然后定义完整性约束;由于完整性约束的限制,被引用的表要先创建。
(4)实验过程
a. 创建名为university的数据库:

b. 删除名为university的数据库:

c. 定义名为university的模式:

注:后续各个实验项目基于当前创建的university数据库
university数据库模式由(课程专业表)course、(系表)department、(教师表)instructor、(课程安排表)section、(学生名单表)student、(学生选课表)takes和(教师上课表)teaches组成。
d. 在university 数据库中创建上述各表,为不同的列选择合适的数据类型以及做好表的完整性约束:





e. 在建立好各个表后,进行数据库的删除,插入和更新操作:
为不冗余复述,以department表为例,其余各表操作类似。
删除操作:

插入操作:

更新数据后department表的结果:

f. 同理对其余各表进行插入数据以及更新操作,为方便后续检查,得到各表格结果如下:
instructor表:


course表:

section表:


teaches表:

student表:

takes表:

实验1.2 数据基本查询
(1)实验目的
掌握SQL程序设计基本规范,熟练运用SQL语言实现数据基本查询,包括单表查询、分组统计查询和连接查询。
(2)实验内容和要求
针对TPC-H数据库设计各种单表查询SQL语句、分组统计查询语句;设计单个表针对自身的连接查询,设计多个表的连接查询。理解和掌握SQL查询语句各个子句的特点和作用,按照SQL程序设计规范写出具体的SQL查询语句,并调试通过。
说明:简单地说,SQL程序设计规范包含SQL关键字大写、表名、属性名、存储过程名等标示符大小写混合、SQL程序书写缩进排列等编程规范。具体内容参见参考文献3。
(3)实验重点和难点
实验重点:分组统计查询、单表自身连接查询、多表连接查询。
实验难点:区分元组过滤条件和分组过滤条件;确定连接属性,正确设计连接条件。
(4)实验过程
a. 单表查询(实现投影操作)
查询教师的编号,姓名和所在系。

查询结果:

b. 单表查询(实现选择操作)
查询所有在computer science系并且工资超过70000美元的教室的姓名。

查询结果:

c. 不带分组过滤条件的分组统计查询
查询找出每个系的平均工资。

查询结果:

d. 带分组过滤条件的分组统计查询
查询平均工资超过42000美元的系及其平均工资。

查询结果:

e. 单表自身连接查询
查询工资至少比Biology系某个老师工资要高的所有老师姓名

查询结果:


f. 两表连接查询
查询大学中所有讲授课程的教师的名字以及所讲述的所有课程标识。

查询结果:

g. 三表连接查询
查询教师的名字以及他们所讲授课程的名称。

查询结果:


实验1.3 数据高级查询
(1)实验目的
掌握SQL嵌套查询和集合查询等各种高级查询的设计方法等。
(2)实验内容和要求
针对TPC-H数据库,正确分析用户查询要求,设计各种嵌套查询和集合查询。
(3)实验重点和难点
实验重点:嵌套查询。
实验难点:相关子查询、多层EXIST嵌套查询。
(4)实验过程
a. in 嵌套查询
查询2009年秋季和2010年春季学期同时开课的所有课程。

查询结果:

b. 单层EXIST嵌套查询
查询2009年秋季和2010年春季学期同时开课的所有课程。

查询结果:

c. FROM子句中的嵌套查询
查询平均工资超过42000美元的系及其平均工资。

查询结果:

d. 由于MySQL没有交集和差集运算,只进行集合并集的查询
查询2009年秋季开课,或者2010年春季开课或两个学期都开课的所有课程。

查询结果:


实验1.4 数据更新
(1)实验目的
熟悉数据库的数据更新操作,能够使用SQL语句对数据库进行数据的插入、修改、删除操作。
(2)实验内容和要求
针对TPC-H数据库设计单元组插入、批量数据插入、修改数据和删除数据等SQL语句。理解和掌握INSERT、UPDATE和DELETE语法结构的各个组成成分,结合嵌套SQL子查询,分别设计几种不同形式的插入、修改和删除数据的语句,并调试成功。
(3)实验重点和难点
实验重点:插入、修改和删除数据的SQL。
实验难点:与嵌套SQL子查询相结合的插入、修改和删除数据的SQL语句;利用一个表的数据来插入、修改和删除另外一个表的数据。
(4)实验过程
a. INSERT基本语句
在student表中插入一条学生记录。

插入结果:

b. UPDATE语句
更新刚才插入的名字属性值为我的名字拼音Feng Xingwei

更新结果:

c. DELETE基本语句
删除刚才插入和修改过的那条编号为11111的记录。

删除后结果:

实验1.5 视图
(1)实验目的
熟悉SQL语言有关视图的操作,能够熟练使用SQL语句来创建需要的视图,定义数据库外模式,并能使用所创建的视图实现数据管理。
(2)实验内容和要求
针对给定的数据库模式,以及相应的应用需求,创建视图、创建带WITH CHECK OPTION的视图,并验证视图WITH CHECK OPTION选项的有效性。理解和掌握视图消解执行原理,掌握可更新视图和不可更新视图的区别。
(3)实验重点和难点
实验重点:创建视图。
实验难点:可更新的视图和不可更新的视图之区别, WITH CHECK OPTION的验证。
(4)实验过程
a. 创建视图
创建一个视图history_instructors,用于列出所有教师中那些归属为历史系的教师信息

b. 使用视图进行操作

操作结果:

c. 不带WITH CHECK OPTION对视图进行更新操作

操作结果:

结论:所以不加WITH CHECK OPTION时可以更新
删除刚才加进来的记录。

d. 带WITH CHECK OPTION对视图进行更新操作
删除之前创建的不带WITH CHECK OPTION的history_instructors视图,重新创建带WITH CHECK OPTION的同名视图,并进行插入操作,代码如下。

实验结果:

插入操作不被允许,原因在于系名为Comp.Sci而不是History所以不允许更新,因此WITH CHECK OPTION得到验证。
MySQL数据库定义与操作语言的更多相关文章
- 【代码学习】MYSQL数据库的常见操作
---恢复内容开始--- ============================== MYSQL数据库的常见操作 ============================== 一.mysql的连接与 ...
- 【代码总结】MYSQL数据库的常见操作
============================== MYSQL数据库的常见操作 ============================== 一.mysql的连接与关闭 -h:指定所连接的服 ...
- python操作mysql数据库的相关操作实例
python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...
- linux系统上Mysql数据库导入导出操作
需求:把MySQL数据库目录中的dz数据库备份到/home/dz_bak.sql ,然后再新建一个数据库dzbak,最后把/home/dz_bak.sql 导入到数据库dzbak中.操作如下:以下操作 ...
- PHP对MySQL数据库的相关操作
一.Apache服务器的安装 <1>安装版(计算机相关专业所用软件---百度云链接下载)-直接install<2>非安装版(https://www.apachehaus.com ...
- mysql 数据库必备命令操作,入门练习一下
mysql 数据库必备命令操作 show databases: 查看所有的数据库: create database jfedu: 创建名为jfedu数据库: use nihao: 进入jfedu数据库 ...
- 第二百七十九节,MySQL数据库-pymysql模块操作数据库
MySQL数据库-pymysql模块操作数据库 pymysql模块是python操作数据库的一个模块 connect()创建数据库链接,参数是连接数据库需要的连接参数使用方式: 模块名称.connec ...
- 第二百七十八节,MySQL数据库-表内容操作
MySQL数据库-表内容操作 1.表内容增加 insert into 表 (列名,列名...) values (值,值,值...); 添加表内容添加一条数据 insert into 表 (列名,列名. ...
- MySQL数据库的常见操作(七)
MySQL数据库的常见操作 1.创建数据库 2.创建重名的数据库以及如何查看警告信息 3.设置数据库的编码方式(默认为utf8) 4.修改和查看数据库的编码方式 5.删除数据库 6.6.删除已经删除了 ...
随机推荐
- 修改myeclipse的servlet模板
今天修改myeclipse的servlet模板时,发生 Could not create the view: An unexpected exception was thrown.错误. 解决方案:1 ...
- 5.HotSpot的算法实现
1.枚举根节点 在可达性分析中,可以作为GC Roots的节点有很多,但是现在很多应用仅仅方法区就有上百MB,如果逐个检查的话,效率就会变得不可接受. 而且,可达性分析必须在一个一致性的快照中进行-即 ...
- CSS透明属性详解
.transparent_class { filter:alpha(opacity=50); -moz-opacity:0.5; -khtml-opacity: 0.5; opacity: 0.5; ...
- 常用linux指令
删除:rm -rf -r 就是向下递归,不管有多少级目录,一并删除 -f 就是直接强行删除,不作任何提示的意思 压缩解压:tar -c: 建立压缩档案 -x:解压 -t:查看内容 -r:向 ...
- oracle 游标使用大全
转:http://www.cnblogs.com/fjfzhkb/archive/2007/09/12/891031.html oracle的游标和例子! 游标-----内存中的一块区域,存放的是se ...
- c# 中定时器的用法
来源于:http://blog.sina.com.cn/s/blog_62c501440100fog1.html System.Threading.Timer 是一个非常常用的定时器类,关于这个类的使 ...
- web可用性测试
1.软件质量模型 2.什么是可用性测试 a. 用户体验 Google搜索界面 ipod iphone b.使用感受 清爽 ,美观,简洁 3. 一位局长使用B/S系统 今天我点名买了个B/S ...
- hibernate cascade=CascadeType.All
因为时间关系,我在这里测试的环境是一对多的关系里面用到的注解方式的级联,网上也有很多贴子,我也看过了,但是呢,我还是自己总结一下吧,这觉得级联是单向的,不是双向的,意思就是说,我们在设置两个类的对象之 ...
- [SmartFoxServer概述]使用文档
如何使用文档和例子 这份文档提供了一份关于如何通过SmartFoxServer 2X(缩写SFS2X)文档掌握要点的快速教程.在使用例子和技术文档之前,我们建议先参考以下主题内容. 不管你是Smart ...
- WordPaster.exe安装教程
安装教程: Firefox控件安装教程 Chrome控件安装教程 Chrome 45+控件安装教程 相关问题: 提示Runtime Error错误 360拦截 Chrome启用npapi Fire ...