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

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 【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月前
|
SQL 机器学习/深度学习 人工智能
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
本文系统性地阐述了自然语言转SQL(NL2SQL) 技术如何让非技术背景的业务分析师实现数据自助查询,从而提升数据驱动决策的效率与准确性。
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
|
7月前
|
人工智能 运维 关系型数据库
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
1261 1
|
4月前
|
SQL 人工智能 Linux
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
457 5
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
|
3月前
|
SQL 存储 监控
SQL日志优化策略:提升数据库日志记录效率
通过以上方法结合起来运行调整方案, 可以显著地提升SQL环境下面向各种搜索引擎服务平台所需要满足标准条件下之数据库登记作业流程综合表现; 同时还能确保系统稳健运行并满越用户体验预期目标.
230 6
|
5月前
|
SQL 人工智能 Java
用 LangChain4j+Ollama 打造 Text-to-SQL AI Agent,数据库想问就问
本文介绍了如何利用AI技术简化SQL查询操作,让不懂技术的用户也能轻松从数据库中获取信息。通过本地部署PostgreSQL数据库和Ollama模型,结合Java代码,实现将自然语言问题自动转换为SQL查询,并将结果以易懂的方式呈现。整个流程简单直观,适合初学者动手实践,同时也展示了AI在数据查询中的潜力与局限。
616 8
|
5月前
|
存储 关系型数据库 MySQL
MySQL数据库中进行日期比较的多种方法介绍。
以上方法提供了灵活多样地处理和对比MySQL数据库中存储地不同格式地日子信息方式。根据实际需求选择适当方式能够有效执行所需操作并保证性能优化。
556 10
|
5月前
|
SQL 人工智能 Linux
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
314 5
|
6月前
|
SQL Oracle 关系型数据库
比较MySQL和Oracle数据库系统,特别是在进行分页查询的方法上的不同
两者的性能差异将取决于数据量大小、索引优化、查询设计以及具体版本的数据库服务器。考虑硬件资源、数据库设计和具体需求对于实现优化的分页查询至关重要。开发者和数据库管理员需要根据自身使用的具体数据库系统版本和环境,选择最合适的分页机制,并进行必要的性能调优来满足应用需求。
321 11
|
6月前
|
SQL 缓存 监控
SqlRest让SQL秒变Http API,还支持20+数据库(含国产数据库)
杭州奥零数据科技有限公司成立于2023年,专注于数据中台业务,维护开源项目AllData并提供商业版解决方案。AllData提供数据集成、存储、开发、治理及BI展示等一站式服务,支持AI大模型应用,助力企业高效利用数据价值。
|
6月前
|
SQL 存储 数据库
SQL Server Management Studio (SSMS) 21 - 微软数据库管理工具
SQL Server Management Studio (SSMS) 21 - 微软数据库管理工具
1113 0

推荐镜像

更多