数据库设计三范式

数据库设计三范式

1NF:要求一张表只描述一件事。比如学生表只能保存学生信息,和学生无关的信息不得保存;

2NF:要求保证表中每一行数据的原子性。即表中不得存在完全相同的数据行,存在完全相同的数据行叫数据冗余(或叫数据副本),这是一种错误,要尽量的减少和避免,无法完全完全消除。解决方案主键或标识,一般的是主键配合标识去用的。

3NF:(外键)表中其他的(外)键要依赖于主(键表)(主键)键而存在。

 

create table StudentCode(

scID int primary key auto_increment,

sCode varchar(18)

);

 

create table Student(

sID int primary key auto_increment,

sName varchar(16),

sAge int,

scID int,#外键列数据来自于主键表主键列

foreign key(scID) references StudentCode(scID)

);

 

insert into StudentCode values(null,'123');

insert into StudentCode values(null,'456');

insert into Student values(null,'zs',18,1);

insert into Student values(null,'ls',19,2);

 

Select sname,sage,scode from student,studentcode

Where student.scid=studentcode.scid;

TIPS:

    • 主键列的一列所有数据行,不得为空并且不得相同,并且一张表中最多只有一个主键,万级数据查询有主键速度更快;
    • 标识列的数据类型只能是整型,在MYSQL中必须是主键才能设置;
    • 使用truncate table 表名; 可以删除标识,但是不能加条件,只能删除所有数据;
    • 标识种子:默认标识种子就是1,可以自由指定,插入时指定后续用null即可。只能改一次不能比原来的数据小。
    • 先建主表设置主键列,再建外键表添加外键列;先插入主表数据,再根据主表数据添加外键列数据;先删除外键表数据,再删除主键表数据;
    • 三范式越标准越规范,但是效率越低,一般人为的违背第三大范式只会遵循1、2范式。

    其他规则

    • 字符串的长度一般最优化,然后再为2的N次方;
    • 在写SQL指令时,看看系统大小写,对应大小写,执行速度还要块;
    • 使用关键字: 用定界符 `` ;
    • 数据名、表名一般情况不用复数。比如Student。

     

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/2924.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚的头像重蔚管理团队
上一篇 2017年10月21日 08:45
下一篇 2017年10月22日 22:28

相关推荐

  • 我来说说mysql数据库锁表怎么解决的。

    MySQL数据库锁表问题通常是由于多个事务竞争同一资源导致的,当一个事务获取了某个数据行的锁,其他事务就必须等待直到该行锁被释放,在某些情况下,这可能导致锁表现象,即整个表被锁定,其他事务无法访问表中的任…

    2024年7月13日
    00
  • 云服务器租用怎么安装数据库。

    当您在云服务器上租用数据库服务时,有多种选择。您可以选择MySQL这种开放源代码的关系型数据库管理系统(RDBMS),它使用最常用的数据库管理语言—结构化查询语言(SQL)进行数据库管理。另一种选择是腾讯云数据库M…

    2024年7月18日
    00
  • mysql的数据操作_修改数据和查询数据

    修改数据 语句:update 表名 set 字段名1=值表达式1,字段名2=值表达式2,....where条件 ; 查询数据 查询数据只有两种结果:真(有数据)或假(没有数据) 语句:select 字段列表 [from子句] 表名 [where子句] [gr…

    2017年11月23日 MySQL自学教程
    0234
  • PHP实现MySQL主从复制自动切换的方法。

    在现代化的应用架构中,数据库是至关重要的一环,对于高负载和高可用性应用,MySQL主从复制架构是广泛采用的一种解决方案。但是在MySQL主从复制模型下,主节点发生故障后需要手动切换从节点为主节点,这不仅会造成…

    2023年5月21日
    04
  • 我来教你MySQL报错:Error 1045(28000)的解决方法。

    简单介绍一下MySQL报错:Error 1045(28000) : user ‘root’@‘localhost’is denied access的解决方法: 服务启动之后,执行mysql -u root -p 报错:Error 1045(28000) : user ‘root’@‘localhost’is denied access Err…

    2024年6月13日
    00
  • mysql_建立索引的优缺点

    建立索引的优缺点: 为什么要创建索引呢? 这是因为,创建索引可以大大提高系统的性能。 第一、通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。第二、可以大大加快 数据的检索速度,这也是创建索引的最…

    2017年10月19日
    0173
  • 小编教你java怎么连接mysql。

    在Java中连接MySQL,需要使用JDBC(Java Database Connectivity)API。首先需要导入相关的库,然后创建一个数据库连接,通过这个连接可以执行SQL语句。 Java连接MySQL数据库是Java开发中常见的操作,下面将详细介绍…

    2024年7月23日
    00
  • 数据库的库操作

    库:存储数据的仓库--起名称 表:存储数据的表,一个库可以创建多个表--起名称 字段:给表中的数据起名称 记录:具体一条数据 1.创建数据库 语句:create database 数据库名 库选项; 库选项:字符集、校对集 2.查询…

    2017年11月21日 MySQL自学教程
    0175

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息