700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > mysql创建表时添加范式 MySql三大范式与数据库设计和表创建常用语句

mysql创建表时添加范式 MySql三大范式与数据库设计和表创建常用语句

时间:2021-02-08 19:06:14

相关推荐

mysql创建表时添加范式 MySql三大范式与数据库设计和表创建常用语句

[导读]第一范式1NF First Normal Fromate:数据表中的每一列字段,必须是不可拆分的最小单元。也就是确保每一列的原子性。

【数据库设计的三大范式】

1.第一范式(1NF First Normal Fromate):数据表中的每一列(字段),必须是不可拆分的最小单元。也就是确保每一列的原子性。

例如:userInfo: '山东省烟台市 13181621008'

=>userAds:'山东省烟台市'

tel:'13181621008'

2.第二范式(2NF):满足1NF后,要求:表中所有的列,都必须功能依赖于主键,而不能有任何一列与主键没有关系。(一张表值描述一件事情)

3.第三范式(3NF):满足2NF后,要求:表中的每一列都要与主键直接相关,而不是间接相关。(表中的每一列,只能依赖于主键)

例如:订单表中,需要有客户相关信息,在分离出客户表之后。订单表中,只需要有一个用户ID

即可。而不能有其他的客户信息。因为,其他的用户信息是直接关联于用户ID。而不是关联于订单ID。

【第二范式与第三范式的本质区别】

在于有没有分出两张表,第二范式是说一张表中包含了多种不同实体的属性,那么必须要分成多张表。第三范式要求,已经分好了多张表的话,那么,一张表中只能有另一张表中的ID(主键),而不能有其他的信息(其他的信息,一律使用主键在另一种查询)。

*/

USE mydb;

-- 创建表:

定义列:列名 数据类型 列定义关键字

常用的列定义关键字:

UNSIGNED:设置列为无符号列。只能设置类型为数字类型的列

AUTO_INCREMENT :设置自动增长列。 自动增长列必须是主键。

【主键】

1.主键的注意事项?① 主键默认非空! ② 只有主键才能设置自动增长(主键不一定自动增长,自动增长必须是主键)

2.设置主键的方式? ① 在列定义时设置:id INT PRIMARY KEY

② 在列定义完成后设置: PRIMARY KEY(id)

UNIQUE:设置唯一性约束。该字段不能出现重复值。

NOT NULL:设置非空约束。该字段不能为空。

DEFAULT:设置默认值约束。hight DOUBLE(3,2) DEFAULT(1.2) height如果不输入默认1.2

FOREIGN KEY:设置外键约束。

【外键】

1、设置外键有哪些注意事项?

1、设置外键有哪些注意事项?

只有innoDB的数据库引擎支持外键。

修改my.ini文件设置default-storage-engine=INNODB

②外键与参照列的数据类型必须相同

③设置外键的字段必须要有索引。如果没有索引,设置外键时会自动生成一个索引

[数值型要求长度和无符号都相同,字符串要求类型相同,长度可以不同]

2、设置外键的语法?

[CONSTRAINT 外键名] FOREIGN KEY(外键字段)REFERENCES 参照表(参照字段)

[ON DELETE SET NULL ON UPDATE CASCADE] -- 设置参照完整性

3、外键约束的参照操作。

参照操作:当对参照表的参照字段进行删除或更新时,外键表中的外键如何应对。

参照操作可选值:DESTRTCT 拒绝参照表删除或更新参照字段

NO ACTION 与 RESTRICT相同,但这个指令只在MySQL生效

CASCADE 删除或更新参照表的参照字段时,外键表的记录同步删除更新

SET NULL 删除或更新参照表的参照字段时,外键表的外键设为NULL

*/CREATETABLEIFNOTEXISTStb1(

idINTUNSIGNEDNOTNULLAUTO_INCREMENTPRIMARYKEY,

`name`VARCHAR(255),

ageSMALLINTUNIQUE,

hightDOUBLE(3,2)DEFAULT(1.2)

);

DROPTABLEIFEXISTSCLASSES;

CREATETABLEIFNOTEXISTSCLASSES(

idINTUNSIGNEDPRIMARYKEYAUTO_INCREMENT,

CLASSNAMEVARCHAR(255)NOTNULL

);

DROPTABLEIFEXISTS`USER`;

CREATETABLEIFNOTEXISTS`USER`(

idINTUNSIGNEDPRIMARYKEYAUTO_INCREMENT,

CLSIDINTUNSIGNEDNOTNULL,

`NAME`VARCHAR(255)NOTNULL,

CONSTRAINTuser_fk_classesFOREIGNKEY(clsid)REFERENCESclasses(id)

);

SHOWCOLUMNSFROMCLASSES;

SHOWTABLES;

-- 显示表结构SHOWCOLUMNSFROMtb1;

-- 显示表的建表语句SHOWCREATETABLESTB1;

-- 删除表DROPTABLEIFEXISTStb1;

-- 修改表名 ALTER TABLE 旧表名 RENAME [TO] 新表名;ALTERTABLETB1RENAMETB2;

-- 同时修改多表名 RENAME TABLE TB3 TO TB1[,`USER` TO USER1 ……];RENAMETABLETB3TOTB1,`USER`TOUSER1;

-- 修改字段 列

-- ALTER TABLE 表名 CHANGE 旧列名 新列名 列定义 [FIRST | AFTER 某一列]

-- FIRST 将这个字段调整为表格第一列 AFTER 某一列:将这个字段放到某一列后面ALTERTABLETB1CHANGE`NAME``USERNAME`VARCHAR(200)NOTNULLAFTERAGE;

-- MODIFY 只修改定义,不能改名ALTERTABLETB1MODIFY`USERNAME`VARCHAR(200)NOTNULLAFTERAGE;

-- 删除表中某一列ALTERTABLETB1DROPHEIGHT;

-- 新增一列 必须部分:ALTER TABLE tb1 ADD HEIGHT DOUBLE(8,2)ALTERTABLEtb1ADDHEIGHTDOUBLE(8,2)DEFAULT1.2AFTERAGE;

-- 新增多列 不能调整列的位置,只能插在最后。ALTERTABLETB1ADD(

WEIGHTDOUBLE(3,2)UNSIGNED,

schoolVARCHAR(255)

)

-- 增加主键约束ALTERTABLEtb1ADDPRIMARYKEY(id);

-- 删除主键约束ALTERTABLEtb1DROPPRIMARYKEY;

-- 新增唯一性约束ALTERTABLETB1ADDUNIQUEKEY(USERNAME);

-- 删除唯一性约束:由于创建唯一性约束会默认创建索引,所以删除时,需删除索引ALTERTABLETB1DROPINDEXUSERNAME;

-- 设置默认值约束ALTERTABLETB1ALTERAGESETDEFAULT20;

-- 删除默认值约束ALTERTABLETB1ALTERAGEDROPDEFAULT;

-- 设置外键约束 必选部分:ALTER TABLE tb1 ADD FOREIGN KEY (CLSID) REFERENCES CLASSES(ID)ALTERTABLEtb1ADDFOREIGNKEY(CLSID)REFERENCESCLASSES(ID)ONDELETESETNULLONUPDATECASCADE;

-- 删除外键约束。由于创建外键时会默认ALTERTABLEtb1DROPFOREIGNKEYTB1_FK_CLASSES;

SHOWCOLUMNSFROMTB1;

SHOWTABLES;

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。