【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 【MySQL】— —熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性

🎯目的:

       熟练掌握用SQL语句实现数据库和基本表的创建。熟练掌握MySQL的安装、客户端登录方法;熟练掌握MySQL的编码、数据类型等基础知识;掌握实体完整性的定义和维护方法、掌握参照完整性的定义和维护方法;掌握用户自定义完整性的定义和维护方法。


🎯内容:

(一)用SQL语句建立如下mystudent数据库,包括studentcoursesc三个基本表,要求实现关系的三类完整性。

学生表student由学号Sno、姓名Sname、性别 Ssex、年龄 Sage、所在系Sdept组成。

表1-1 student表

Sno

Sname

Ssex

Sage

Sdept

201215121

李勇

20

CS

201215122

刘晨

19

CS

201215123

王敏

18

MA

201215125

张立

19

IS

CREATE TABLE Student          
      (Sno   CHAR(9)  PRIMARY  KEY,  /* 列级完整性约束条件,Sno是主码*/                  
        Sname  CHAR(20)  UNIQUE,     /* Sname取唯一值*/
        Ssex    CHAR(2),
        Sage   SMALLINT,
        Sdept  CHAR(20)
      )charset utf8; 
 
插入数据:
INSERT INTO student VALUES
("201215121","李勇","男",20,"CS"),
("201215122","刘晨","女",19,"CS"),
("201215123","王敏","女",18,"MA"),
("201215125","张立","男",19,"IS");

课程表course由课程号Cno、课程名Cname、先行课Cpno、学分Ccredit组成。

表1-2 course表

Cno

Cname

Cpno

Ccredit

1

数据库

5

4

2

数学

2

3

信息系统

1

4

4

操作系统

6

3

5

数据结构

7

4

6

数据处理

2

7

PASCAL语言

6

4

CREATE TABLE  Course
          (Cno       CHAR(4)  PRIMARY  KEY,
           Cname  CHAR(40),            
           Cpno     CHAR(4),                                      
            Ccredit  SMALLINT,
            FOREIGN KEY (Cpno) REFERENCES  Course(Cno) 
          ) charset utf8;
插入数据:
 
INSERT INTO course (Cno,Cname,Ccredit) VALUES
("1","数据库",4),
("2","数学",2),
("3","信息系统",4),
("4","操作系统",3),
("5","数据结构",4),
("6","数据处理",2),
("7","PASCAL语言",4);
 
update course set Cpno = case Cno
  when '1' then '5'
  when '3' then '1'
  when '4' then '6'
  when '5' then '7'
  WHEN '7' then '6'
  end
WHERE Cno IN('1','3','4','5','7');

选课表sc由学号Sno、课程号Cno、成绩Grade组成。

表1-3 sc表

Sno

Cno

Grade

201215121

1

92

201215121

2

85

201215121

3

88

201215122

2

90

201215122

3

80

CREATE TABLE  SC
          (Sno  CHAR(9), 
           Cno  CHAR(4),  
           Grade  SMALLINT,
           PRIMARY KEY (Sno,Cno),  
           FOREIGN KEY (Sno) REFERENCES Student(Sno),
           FOREIGN KEY (Cno)REFERENCES Course(Cno)
        ) charset utf8;
插入数据:
INSERT INTO sc(Sno,Cno,Grade) values
("201215121","1",92),
("201215121","2",85),
("201215121","3",88),
("201215122","2",90),
("201215122","3",80);

(二)用SQL语句建立如下mySPJ数据库,包括S,P,J,和SPJ四个基本表(教材第二章习题5中的四个表),要求实现关系的三类完整性。


S(SNO,SNAME,STATUS,CITY);


P(PNO,PNAME,COLOR,WEIGHT);


J(JNO,JNAME,CITY);


SPJ(SNO,PNO,JNO,QTY)


供应商表S由供应商代码(SNO)、供应商姓名(SNAME)、供应商状态(STATUS)、供应商所在城市(CITY)组成。

表1-4 供应商表S

SNO

SNAME

STATUS

CITY

S1

精益

20

天津

S2

盛锡

10

北京

S3

东方红

30

北京

S4

丰泰盛

20

天津

S5

为民

30

上海


CREATE TABLE S
(SNO CHAR(4) PRIMARY KEY,
SNAME CHAR(4),
STATUS CHAR(4),
CITY CHAR(4)
)CHARSET utf8;
插入数据:
INSERT INTO s VALUES
("S1","精益","20","天津"),
("S2","盛锡","10","北京"),
("S3","东方红","30","北京"),
("S4","丰泰盛","20","天津"),
("S5","为民","30","上海");

零件表P由零件代码(PNO)、零件名(PNAME)、颜色(COLOR)、重量(WEIGHT)组成。

表1-5 零件表P

PNO

PNAME

COLOR

WEIGHT

P1

螺母

12

P2

螺丝

绿

17

P3

螺丝刀

14

P4

螺丝刀

14

P5

凸轮

40

P6

齿轮

30

CREATE TABLE p
(PNO CHAR(4) PRIMARY KEY,
PNAME CHAR(4),
COLOR CHAR(4),
WEIGHT char(4)
)CHARSET utf8;
插入数据:
INSERT INTO p VALUES
("P1","螺母","红","12"),
("P2","螺丝","绿","17"),
("P3","螺丝刀","蓝","14"),
("P4","螺丝刀","红","14"),
("P5","凸轮","蓝","40"),
("P6","齿轮","红","30");

工程项目表J由工程项目代码(JNO)、工程项目名(JNAME)、工程项目所在城市(CITY)组成。

表1-6 工程项目表J

JNO

JNAME

CITY

J1

三建

北京

J2

一汽

长春

J3

弹 簧 厂

天津

J4

造 船 厂

天津

J5

机 车 厂

唐山

J6

无线电厂

常州

J7

半导体厂

南京

CREATE TABLE j
(JNO CHAR(4),
JNAME CHAR(4),
CITY CHAR(4)
)CHARSET utf8;  
插入数据:
INSERT INTO j VALUES
("J1","三建","北京"),
("J2","一汽","长春"),
("J3","弹簧厂","天津"),
("J4","造船厂","天津"),
("J5","机车厂","唐山"),
("J6","无线电厂","常州"),
("J7","半导体厂","南京");

供应情况表SPJ由供应商代码(SNO)、零件代码(PNO)、工程项目代码(JNO)、供应数量(QTY)组成,表示某供应商 供应某种零件 给某工程项目的数量为QTY。

表1-7 供应情况表SPJ

SNO

PNO

JNO

QTY

S1

P1

J1

200

S1

P1

J2

5000

S1

P1

J3

100

S1

P1

J4

700

S1

P2

J2

100

S2

P3

J1

400

S2

P3

J2

200

S2

P3

J4

500

S2

P3

J5

400

S2

P5

J1

400

S2

P5

J2

100

S3

P1

J1

200

S3

P3

J1

200

S4

P5

J1

100

S4

P6

J3

300

S4

P6

J4

200

S5

P2

J4

100

S5

P3

J1

200

S5

P6

J2

200

S5

P6

J4

500

CREATE TABLE spj
(SNO CHAR(4),
PNO CHAR(4),
JNO CHAR(4),
QTY char(4),
PRIMARY KEY (SNO,PNO,JNO),
FOREIGN KEY (SNO) REFERENCES s(SNO),
FOREIGN KEY (PNO) REFERENCES p(PNO),
FOREIGN KEY (JNO) REFERENCES j(JNO)
)CHARSET utf8;
插入数据:
INSERT INTO spj VALUES
("S1","P1","J1","200"),
("S1","P1","J2","5000"),
("S1","P1","J3","100"),
("S1","P1","J4","700"),
("S1","P2","J2","100"),
("S2","P3","J1","400"),
("S2","P3","J2","200"),
("S2","P3","J4","500"),
("S2","P3","J5","400"),
("S2","P5","J1","400"),
("S2","P5","J2","100"),
("S3","P1","J1","200"),
("S3","P3","J1","200"),
("S4","P5","J1","100"),
("S4","P6","J3","300"),
("S4","P6","J4","200"),
("S5","P2","J4","100"),
("S5","P3","J1","200"),
("S5","P6","J2","200"),
("S5","P6","J4","500");
SELECT *FROM spj;

🎯 结果截图:

(一)用SQL语句建立如下mystudent数据库,包括studentcoursesc三个基本表,要求实现关系的三类完整性。

1.创建一张学生表

2.创建一张课程表

3.创建一张选课表

(二)用SQL语句建立如下mySPJ数据库,包括SPJ,和SPJ四个基本表(教材第二章习题5中的四个表),要求实现关系的三类完整性。

1.创建供应商表S由供应商代码(SNO)、供应商姓名(SNAME)、供应商状态(STATUS)、供应商所在城市(CITY)组成。

2.创建零件表P由零件代码(PNO)、零件名(PNAME)、颜色(COLOR)、重量(WEIGHT)组成。

3.创建工程项目表J由工程项目代码(JNO)、工程项目名(JNAME)、工程项目所在城市(CITY)组成。


f39635a0e41a836e6f14335e860bbaf6_39c56b6b20204ddf9cc8614352dff475.png


4.创建供应情况表SPJ由供应商代码(SNO)、零件代码(PNO)、工程项目代码(JNO)、供应数量(QTY)组成,表示某供应商 供应某种零件 给某工程项目的数量为QTY。

d6691ba3adceb237c7a6835b16fee116_084ee187277448588c9aa605d263d4ad.png


🎯问题及解决:


问题一:主码可以为可以为空吗?


答:主码并不能为空值,必须取值。


问题二:为什么有的主码无法删除,如果想要删除,应如何做?


答:因为有的主码会被其他表中的外码中作为参考,无法删除。要想删除,必须先把其他表中的外码删除,再删除这个主码。


问题三:如果外码和其参考码在同一个表中应如何编辑数据?


答:应该先插入参考码和其他码(外码先不插入数据),插入完成之后,再去更新(一定要是update更新,而不是insert插入)外码的值。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
5月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1040 152
|
5月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
815 156
|
5月前
|
SQL 人工智能 Linux
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
542 5
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
|
4月前
|
SQL 存储 监控
SQL日志优化策略:提升数据库日志记录效率
通过以上方法结合起来运行调整方案, 可以显著地提升SQL环境下面向各种搜索引擎服务平台所需要满足标准条件下之数据库登记作业流程综合表现; 同时还能确保系统稳健运行并满越用户体验预期目标.
312 6
|
5月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
5月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
605 11
|
5月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
444 158
|
5月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
5月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
427 156
|
5月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
530 161