数据库建表语句的使用及简单实战教程_SQL数据库建立一个表

数据库建表语句的使用及简单实战教程_SQL数据库建立一个表目录介绍需求思路思路1:一张表来表示所有数据(如下图)思路2:两张表,学生表和班级表(如下图)代码扩展1.数据库设计三范式1.数据库表中不能出现重复记录,每个字段是原子性的不能再分(不可重复,不可再分)2.第二范式是建立在第一范式基础上的,另外要求所有非主键字段完全依赖主键,不能产生部分依赖3.建立在第二范式基础上的,非主键字段不能传递依赖于主键字段。(不要产生传递依赖)2.经典的数据库设计框架–er图介绍本文将用一个简单的tip来简单介绍建表语句,可以作为建表语句的模板使用需求采集一个学校中学生

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

介绍

本文将用一个简单的tip来简单介绍建表语句,可以作为建表语句的模板使用

需求

采集一个学校中学生的信息,学生具有班级姓名学号等属性

思路

思路1:一张表来表示所有数据(如下图)

在这里插入图片描述
缺点:产生大量的数据冗余

思路2:两张表,学生表和班级表(如下图)

在这里插入图片描述
优点:优化空间,数据具有条理性

思路2将班级编号cno作为外键,且加上非空,这样子的话一个学生一定对应了一个班级。这个时候,学生表叫做子表,班级表叫做父表。

外键:外键的内容一定要是父表对应字段中存在的内容,如果没有该内容,则会添加数据失败,报错。

代码

drop table if exists t_classes;
create table t_classes(
	classes_id	int (3),
	classes_name	varchar(30)	not null,
	constraint	pk_classes_id	primary key(classes_id) 
)

drop table if exists t_student;
create table t_student(
	student_id	int(10),
	student_name 	varchar(50) not null,
	sex		char(2) not null,
	birthday	date not null,
	email		varchar(30) unique,
	classes_id	int (3) not null,
	primary key(student_id),
	foreign key(classes_id) references t_classes(classes_id) 
)

扩展

1.数据库设计三范式

1.数据库表中不能出现重复记录,每个字段是原子性的不能再分(不可重复,不可再分)

在这里插入图片描述
其中联系方式可以再分,不是原子性

2.第二范式是建立在第一范式基础上的,另外要求所有非主键字段完全依赖主键,不能产生部分依赖

在这里插入图片描述
以上虽然确定了主键,但此表会出现大量的冗余,主要涉及到的冗余字段为“学生姓名”和“教师姓名”,出现冗余的原因在于,学生姓名部分依赖了主键的一个字段学生编号,而没有依赖教师编号,而教师姓名部门依赖了主键的一个字段教师编号,这就是第二范式部分依赖。

解决方法:绘制两张表
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
如果一个表是单一主键,那么它就复合第二范式,部分依赖和主键有关系

以上是一种典型的“多对多”的设计

3.建立在第二范式基础上的,非主键字段不能传递依赖于主键字段。(不要产生传递依赖)

在这里插入图片描述
从上表可以看出,班级名称字段存在冗余,因为班级名称字段没有直接依赖于主键,班级名称字段依赖于班级编号,班级编号依赖于学生编号,那么这就是传递依赖,解决的办法是将冗余字段单独拿出来建立表,如下:

在这里插入图片描述
在这里插入图片描述
以上设计是一种典型的一对多的设计,一存储在一张表中,多存储在一张表中,在多的那张表中添加外键指向一的一方的主键。(外键指向主键)

2.经典的数据库设计框架–er图

E-R图也称实体-联系图(Entity Relationship Diagram),提供了表示实体类型、属性和联系的方法,用来描述现实世界的概念模型。

它是描述现实世界关系概念模型的有效方法。是表示概念关系模型的一种方式。用“矩形框”表示实体型,矩形框内写明实体名称;用“椭圆图框”或圆角矩形表示实体的属性,并用“实心线段”将其与相应关系的“实体型”连接起来;

用”菱形框“表示实体型之间的联系成因,在菱形框内写明联系名,并用”实心线段“分别与有关实体型连接起来,同时在”实心线段“旁标上联系的类型

用来表现数据对象与数据对象之间的联系,例如学生的实体和成绩表的实体之间有一定的联系,每个学生都有自己的成绩表,这就是一种关系,关系用菱形来表示。(如下图)
在这里插入图片描述

最后,推荐一个优质的mysql课程,我听过的几个课中可以说是讲的最好的老师了。相关链接

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195955.html原文链接:https://javaforall.net

(0)
上一篇 2025年10月7日 上午8:43
下一篇 2025年10月7日 上午9:15


相关推荐

  • vue 数组对象去重

    vue 数组对象去重that phoneList that unique that phoneList unique arr constres newMap returnarr filter arr gt res has arr id amp amp res set arr id 1 其中以 id 作为检验数据的唯一

    2026年3月18日
    2
  • VS自带反编译DLL工具「建议收藏」

    VS命令提示符下输入ILDasm转载于:https://www.cnblogs.com/Impulse/p/4022413.html

    2022年4月12日
    42
  • ViewGroup的LayoutParams理解[通俗易懂]

    ViewGroup的LayoutParams理解[通俗易懂]LayoutParams是ViewGroup的一个内部类,声明方式如下publicstaticclassLayoutParams{publicstaticfinalintMATCH_PARENT=-1;publicstaticfinalintWRAP_CONTENT=-2;publicintwidth;publicintheight;

    2025年11月27日
    5
  • crontab 详解

    crontab 详解cron 是一个可以用来根据时间 日期 月份 星期的组合来调度对重复任务的执行的守护进程 cron 假定系统持续运行 如果当某任务被调度时系统不在运行 该任务就不会被执行 要使用 cron 服务 你必须安装了 nbsp vixie cron nbsp RPM 软件包 而且必须在运行 crond nbsp 服务 要判定该软件包是否已安装 使用 nbsp rpm qvixie cron nbsp 命令 要判定该服务是否在运行 使

    2026年3月17日
    1
  • Linux中top命令_linux tail命令详解

    Linux中top命令_linux tail命令详解原标题:Linux下top命令详解1、简介top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。top显示系统当前的进程和其他状况,是一个动态显示过程,可以自动或者通过用户按键来不断刷新当前状态。如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.。比较准确的说,top命令提供了实时的对系统处理器的状态监控,显示系统中CPU…

    2026年3月8日
    7
  • linux手动安装gcc-5.1.0「建议收藏」

    linux手动安装gcc-5.1.0「建议收藏」yum源和apt-get源安装linux下安装gcc和g++时,可以使用源安装,例如:yuminstallgcc或者apt-getinstallgcc,但是这有个缺点,就是可能不能安装到你想要的版本,因此我们需要手动安装。下载gcc不同版本gcc是gnu的产品,所以我们可以去gnu官网去下,但是gnu下载的比减慢,这里提供一些大学的软件开元镜像源,比如清华大学:清华大学开元镜像源…

    2022年5月26日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号