约束

1.约束

1.约束保证数据的完整性和一致性

2.约束分为表级约束和列级约束

3.约束类型包括:

NOT NULL(非空约束)

PRIMARY KEY(主键约束)

UNIQUE KEY(唯一约束)

DEFAULT(默认约束)

FOREIGN KEY(外键约束)

外键约束:(FOREIGN KEY)

保持数据一致性,完整性。

实现一对一或一对多关系。

外键约束的要求:

1.父表和子表必须使用相同的存储引擎,而且禁止使用临时表。

2.数据表的存储引擎只能为InnoDB。

3.外键列和参照列必须具有相似的数据类型,其中数字的长度或是否有符号位必须相同;而字符的长度则可以不同。

4.外键列和参照列必须穿件索引。如果外键列不存在索引的话mysql讲自动创建索引。

编辑数据表的默认存储引擎:

MySQL配置文件

default-storage-engine=INNODB

eg:CREATE TABLE provinces(id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,pname VARCHAR(20) NOT NULL);

CREATE TABLE users(id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,username VARCHAR(10) NOT NULL,pid BIGINT,FOREIGN KEY (pid) REFERENCES privinces(id));

CREATE TABLE users(id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,username VARCHAR(10) NOT NULL,pid SMALLINT UNSIGNED,FOREIGN KEY(pid) REFERENCES provinces(id));

//查看索引使用命令:SHOW INDEXES FROM provinces\G;和SHOW INDEXES FROM users\G;

//SHOW CREATE TABLE users;

外键约束的参照操作

1.CASCADE:从父表删除或更新且自动删除或更新子表中匹配的行;

2.SET NULL:从父表删除或更新行,并设置子表中的外键列为NULL。如果使用该选项,必须保证子表列没有指定NOT NULL.

3.RESTRICT:拒绝对父表的删除或更新操作。

4.NOACTION:标准SQL的关键字,在MYSQL中与RESTRICT相同。

删除表中的数据:

DELETE FROM provinces WHERE id=3;

增加表中数据:

INSERT USERS1(username,pid) VALUES('Tom',3);

查看表中所有数据:

SELECT * FROM provinces;

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 回顾和概述 数据类型 整型 浮点型 字符型 日期时间型 数据表操作 如何创建数据表 PRIMARY KEY(主键约...
    齐天大圣李圣杰阅读 731评论 0 0
  • 1、约束概述 约束的目的是为了保证数据的完整性与一致性。 按照约束的范围划分:列级约束:只对一个数据列建立约束。既...
    黒猫阅读 1,013评论 3 5
  • 约束 一、非空约束(not null) 1.1、在创建表时设置非空约束 语法:create table 表名(字段...
    lingoling阅读 780评论 0 0
  • 第1章 初涉MySQL 1.1 MySQL文件 (1)MySQL目录结构 (2)MySQL配置向导文件(安装后配置...
    凛0_0阅读 860评论 1 0
  • 这两天心情其实一直都不错,潜心在象山拍戏,没有其他行程。元凌,西魏皇子,玄甲军统帅,素有战神之称。他充满狼性、心思...
    等猴抱兔阅读 1,554评论 17 34