表的完整性约束

约束条件与数据类型的宽度一样,都是可选参数

作用:用于保证数据的完整性和一致性

主要分为:

not null  标识该字段不能为空

default   为该字段设置默认值

unsigned  无符号

zerofill   使用0填充

auto_increment  标识该字段的自动增长(整数类型,而且为主键)

primary key   标识该字段为该表的主键,可以唯一的标识记录

foreign key   标识该字段为该表的外键

unique key    标识该字段的值是唯一的

一、not null与default

create table t1(

id int primary key auto_increment,

name varchar(16) not null,

sex enum(‘nale’,’female’) not null default ‘male’

);

Insert into t1(name) values(‘egon’),(‘lxx’),(‘alex’);

二、unique key

create table t2(x int unique);

create table t3(

x int,

y varchar(5),

unique key(x)

);

create table t4(

x int,

y varchar(5),

constraint uni_x unique key(X)

);  # 给键取名

create table service(

ip varchar(15),

port int,

unique key(ip,port)

);  # 联合唯一

三、primary key

站在约束角度看primary key = not null unique

以后但凡建表,必须注意:

1、必须有且只有一个主键

2、通常是id字段被设置为主键

create table t5(

id int primary key auto_increment

);

# 补充存储引擎:

create table t12(x int)engine='myisam';  #会创建三个文件

create table t13(x int)engine='innodb';   #一般都用这个,创建两个,主键与数据在一个表中

create table t14(x int)engine='memory';       #内存中,服务端关机消失

create table t15(x int)engine='blackhole';   #不会有任何数据信息

四、foreign key:限制关联表某一个字段的值必是来自于被关联表的一个字段的

注意:

1.被关联的字段必须是一个key,通常是id字段

2.创建表时:必须先建立被关联的表,才能建立关联表

3.插入记录时:必须先往被关联的表中插入记录,才能往关联表中插入记录

4.删除时:应该先删除关联表emp中的记录,再删除被关联表对应的记录

create table dep(

id int primary key auto_increment,

dname varchar(20),

info varchar(50)

);

create table emp(

id int primary key auto_increment,

name varchar(15),

age int,

dep_id int,

foreign key(dep_id) references dep(id)

on update cascade

on delete cascade

);

insert into dep(dname,info) values

(‘IT’,’技术能力有限部门’),

(‘sale’,’文化程度不高部门’),

(‘HR’,’招不到人部门’);

insert into emp(name,age,dep_id) values

('egon',18,1),

('alex',28,2),

('wsj',38,2),

('lxx',30,1),

('xiaohou',18,3);

# 找两张表的关系的窍门

emp        dep

#1、先站在左表的角度:去找左表emp的多条记录能否对应右表dep的一条记录

翻译:多个员工能否属于一个部门

#2、然后站在右表的角度:去找右表dep的多条记录能否对应左表emp的一条记录

翻译:多个部门能否拥有同一名员工

# 多对一:结果的判断

#1、如果只有单向的多对一成立,那么最终的关系就是多对一

#2、在emp表新增一个字段dep_id, 该字段外键关联dep(id)

# 多对多:结果的判断

#1、双向的多对一就是多对多

#2、需要建立第三张表,有一个字段值fk左表,一个字段的值fk右表

create table author(

id int primary key auto_increment,

name varchar(16),

age int

);

create table book(

id int primary key auto_increment,

bname varchar(20),

price int

);

create table author2book(

id int primary key auto_increment,

author_id int,

book_id int,

foreign key(author_id) references author(id) on update cascade on delete cascade,

foreign key(book_id) references book(id) on update cascade on delete cascade

);

# 一对一:无需参考窍门,左表的一条数据唯一对应右表的一条记录

fk+unique

mysql表相关操作的更多相关文章

  1. mysql 表相关操作(1)

    查询语句 select * from t_deptselect empno,ename,sal from t_emp select    empno,   sal * 12 as "inco ...

  2. MYSQL初级学习笔记二:数据表相关操作及MySQL存储引擎!(视频序号:初级_5,7-22|6)

    知识点三:数据表相关操作(5,7-22) --------------------------------整型--------------------------------- --测试整型 CREA ...

  3. MySQL数据库(二)--库相关操作、表相关操作(1)、存储引擎、数据类型

    一.库相关操作 1.创建数据库 (1)语法 create database 数据库 charset utf8; (2)数据库命名规范 可以由字母.数字.下划线.@.#.$ 区分大小写 唯一性 不能使用 ...

  4. MySQL数据库(三)—— 表相关操作(二)之约束条件、关联关系、复制表

    表相关操作(二)之约束条件.关联关系.复制表 一.约束条件  1.何为约束 除了数据类型以外额外添加的约束 2.约束条件的作用 为了保证数据的合法性,完整性 3.主要的约束条件 NOT NULL # ...

  5. MySQL数据库(二)——库相关操作、表相关操作(一)、存储引擎、数据类型

    库相关操作.表相关操作(一).存储引擎.数据类型 一.库相关操作 1.创建数据库 (1)语法 create database 数据库 charset utf8; (2)数据库命名规范 可以由字母.数字 ...

  6. MySQL之表相关操作

    一 存储引擎介绍 存储引擎即表类型,mysql根据不同的表类型会有不同的处理机制 详见:http://www.cnblogs.com/linhaifeng/articles/7213670.html ...

  7. MySQL数据库(三)--表相关操作(二)之约束条件、关联关系、复制表

    一.约束条件  1.何为约束 除了数据类型以外额外添加的约束 2.约束条件的作用 为了保证数据的合法性,完整性 3.主要的约束条件 NOT NULL # 标识该字段不能为空,默认NULL,可设置NOT ...

  8. 安装Mysql的一些问题,比如Net Connect 卸载不掉,注册表相关操作

    我安装mysql用了一段时间后卸载了,在安装就发现安装不了了,原因就是卸载的时候Net Connetc无法卸载,我试了一个月也没有解决后来百度各种还是没有办法解决.于是就尝试自己手动卸载注册表.在“开 ...

  9. MySql学习笔记【三、表相关操作】

    创建表 CREATE TABLE [IF NOT EXISTS] table_name( column_name data_type, ... ) 如: CREATE TABLE test_table ...

随机推荐

  1. 阅读关于DuReader:百度大规模的中文机器阅读理解数据集

    很久之前就得到了百度机器阅读理解关于数据集的这篇文章,今天才进行总结!.... 论文地址:https://arxiv.org/abs/1711.05073 自然语言处理是人工智能皇冠上的明珠,而机器阅 ...

  2. 【DataScience学习笔记】Coursera课程《数据科学家的工具箱》 约翰霍普金斯大学——Week3 Conceptual Issues课堂笔记

    Coursera课程<数据科学家的工具箱> 约翰霍普金斯大学 Week3 Conceptual Issues Types of Questions Types of Data Scienc ...

  3. 金融分析二:Matplotlib模板

    Matplotlib:绘图和可视化 Matplotlib是一个强大的Python绘图和数据可视化的工具包. 安装方法:pip install matplotlib 引用方法:import matplo ...

  4. 内存分配器memblock【转】

    转自:http://blog.csdn.net/kickxxx/article/details/54710243 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] 背景 Data ...

  5. perl_nc.pl

    #!/usr/bin/perl use strict; use IO::Socket; use IO::Select; use Getopt::Std; my %option;getopts('lp: ...

  6. 【python】msgpack使用

    1.存储数据 import msgpack var={'a':'this','b':'is','c':'a test'} with open('file.name','wb') as f: msgpa ...

  7. JVM监控常用命令行工具

    jps jps -mlv //列出正在运行的虚拟机进程 jstat jstat -gc pid //监视java堆状况 显示列名 具体描述 S0C 年轻代中第一个survivor(幸存区)的容量 (字 ...

  8. mysql远程访问cannot connect(10038) 问题解决的过程

    今天用Navicat访问虚拟机上的mysql,无法访问报cannot connect(10038). 首先看是否可以telnet,本机cmd,telnet 192.168.209.128 3306,结 ...

  9. phpcms v9表单向导添加验证码

    要做留言板的功能,故用添加表单,想要在提交留言前加一个验证码的功能.网上的教程比较混乱,于是亲自实验了下,步骤如下: 首先是调用表单的页面加入验证码.表单js调用模版默认的是 \phpcms\temp ...

  10. redis 安装配置

    reids 安装配置 1.1 下载软件包 [root@node01 ~]# mkdir -p /data/src/ [root@node01 ~]# cd /data/src/ [root@node0 ...