首页 > 数据库 >mysql-3

mysql-3

时间:2022-08-16 22:04:05浏览次数:57  
标签:name int auto primary key mysql id

目录

约束条件

1.primary key主键
	1.单从约束角度上而言主键等价于非空且唯一 not null unique
    	create table t1(
           id int primary key,
           name varchar(32)
        ); 
 	2.InnoDB存储引擎规定一张表必须有且只有一个主键
    	2.1.如果创建的表中没有主键也没有非空且唯一的字段 那么InnoDB存储引擎会自动采用一个隐藏的字段作为主键(主键可以加快数据查询:新华字典的目录)
   		2.2.如果创建的表中没有主键但是有非空且唯一的字段 那么InnoDB存储引擎会自动将该字段设置为主键
        	create table t2(
               nid int not null unique,
               sid int not null unique,
               uid int not null unique,
               name varchar(32)
        	); 
	3.创建表的时候都应该有一个'id'字段 并且该字段应该作为主键
    		uid、sid、pid、gid、cid、id
	补充说明
    		id int primary key  单列主键
			
          sid int,
			nid int,
			primary key(sid, nid)  联合主键
           
2.auto_increment自增
	该约束条件不能单独使用 必须跟在键后面(主要配合主键一起使用)
		create table t3(
        	id int auto_increment
        );
	there can be only one auto column and it must be defined as a key
		create table t4(
        	id int primary key auto_increment,
        	name varchar(32)
        );
    
 	补充说明:自增的特点
		自增的操作不会因为执行删除数据的操作而回退或者重置
			delete from 
		如果非要重置主键 需要格式化表
			truncate 表名;  # 删除表数据并重置主键值

约束条件之外键

1.外键前戏
	需要创建一张员工表
		id	name gender	dep_name dep_desc
	上述表的缺陷
        1.表结构不清晰 到底是员工表还是部门表(不严重 无所谓)
        2.字段数据反复存取 浪费存储空间(不严重 无所谓)
        3.表的扩展性极差 牵一发动全身(很严重 效率极低)
	优化操作>>>:拆表
        id	name	  gender
        id	 dep_name	dep_desc
        拆表之后解决了上述的三个问题 但是出现了一个致命的缺陷
   	解决措施
        id		name	gender 		dep_id
		添加一个部门编号字段填写部门数据的主键值
   	外键字段
		专门用于记录表与表之间数据的关系
  
2.外键字段的创建
	外键字段是用来记录表与表之间数据的关系 而数据的关系有四种
        一对多关系
        多对多关系
        一对一关系
        没有关系
	2.1.表数据关系的判定  >>>: '换位思考'
      针对员工表和部门表判断数据关系
    		1.先站在员工表的角度
                问:一条员工数据能否对应多条部门数据
                翻:一名员工能否属于多个部门
                答:不可以
          2.再站在部门表的角度
                问:一条部门数据能否对应多条员工数据
                翻:一个部门能否拥有多个员工
                答:可以
          完成换位思考之后得出的答案 一个可以一个不可以
          那么表关系就是"一对多"
            	部门是一 员工是多
          针对'一对多'的关系 外键字段建在多的一方 
          ps:没有多对一 统一称为'一对多'

Foreign Key

1.先写普通字段
2.然后再写外键字段   

create table emp(
    id int primary key auto_increment,
    name varchar(32),
    gender enum('male','female','others') default 'male',
    dep_id int,
    foreign key(dep_id) references dep(id)
);
create table dep(
    id int primary key auto_increment,
    dep_name varchar(32),
    dep_desc varchar(32)
);
"""
1.创建表的时候需要先创建被关联的表(没有外键) 然后再是关联表(有外键)
2.插入表数据的时候 针对外键字段只能填写被关联表字段已经出现过的数据值
3.被关联字段无法修改和删除
	有点不太好 操作限制性太强
"""
级联更新、级联删除
	被关联数据一旦变动 关联的数据同步变动
create table emp1(
    id int primary key auto_increment,
    name varchar(32),
    gender enum('male','female','others') default 'male',
    dep_id int,
    foreign key(dep_id) references dep1(id) 
    on update cascade  # 级联更新 
    on delete cascade  # 级联删除
);
create table dep1(
    id int primary key auto_increment,
    dep_name varchar(32),
    dep_desc varchar(32)
);
"""
扩展:
    在实际工作中 很多时候可能并不会使用外键
        因为外键增加了表之间的耦合度 不便于单独操作 资源消耗增加
    我们为了能够描述出表数据的关系 又不想使用外键
        自己通过写SQL 建立代码层面的关系
"""

表关系之多对多

以书籍表和作者表为例
	1.先站在书籍表的角度
		问:一条书籍数据能否对应多条作者数据
		答:可以
	2.再站在作者表的角度
    	问:一条作者数据能否对应多条书籍数据
		答:可以
	总结:两边都可以 那么表数据关系就是'多对多'
	针对多对多表关系 外键字段不能建在任意一方!!!
   		create table book(
            id int primary key auto_increment,
            title varchar(32),
            author_id int,
            foreign key(author_id) references author(id) 
            on update cascade  # 级联更新 
            on delete cascade  # 级联删除
        );
       create table author(
           id int primary key auto_increment,
           name varchar(32),
           book_id int,
           foreign key(book_id) references book(id) 
           on update cascade  # 级联更新 
           on delete cascade  # 级联删除
       );
	需要单独开设第三张关系表 存储数据关系
            create table book(
                id int primary key auto_increment,
                title varchar(32)
        );
            create table author(
                id int primary key auto_increment,
                name varchar(32)
       );
            create table book2author(
                id int primary key auto_increment,
                book_id int,
                foreign key(book_id) references book(id) 
                on update cascade  # 级联更新 
                on delete cascade, # 级联删除
                author_id int,
                foreign key(author_id) references author(id) 
                on update cascade  # 级联更新 
                on delete cascade  # 级联删除
        );

表关系之一对一

以用户表和用户详情表
	1.先站在用户表的角度
  	2.再站在用户详情表的角度
   总结:两边都不可以 那么先考虑是不是没有关系
    	如果有关系那么肯定就是'一对一'
   针对'一对一'的表关系 外键字段建在任何一张表都可以 但是建议你建在查询频率较高的表中便于后续查询
   create table user(
       id int primary key auto_increment,
       name varchar(32)
       detail_id int unique,
       foreign key(detail_id) references userDetail(id) 
       on update cascade  # 级联更新 
       on delete cascade  # 级联删除
   );
	create table userDetail(
        id int primary key auto_increment,
        phone bigint
    );

标签:name,int,auto,primary,key,mysql,id
From: https://www.cnblogs.com/zzjjpp/p/16593140.html

相关文章

  • Mysql
    --查看所有变量showvariables;--查看当前mysql最大连接数SHOWVARIABLESLIKE'max_connections%';--查看当前慢日志的入录时长单位是(秒)showvariableslike'long%'......
  • MySQL查询执行流程-SQL解析顺序
    前言一直是想知道一条SQL语句是怎么被执行的,它执行的顺序是怎样的,然后查看总结各方资料,就有了下面这一篇博文了。本文将从MySQL总体架构--->查询执行流程--->语......
  • MySQL 日期相关
    NOW()返回当前的日期和时间CURDATE()返回当前的日期CURTIME()返回当前的时间DATE()提取日期或日期/时间表达式的日期部分EXTRACT()返回日期/时间按的单独部分DAT......
  • 【2022.8.16】MySQL数据库(3)
    学习内容概要约束条件之主键约束条件之外键操作表的SQL语句补充内容详细约束条件1.主键:primarykey主键含义:从约束角度上而言主键等于非空且唯......
  • Mysql limit、offset 使用
    1、原表数据//全表数据select*fromsummer_test;2、使用limit//查询符合条件的4条数据,如果只有1条数据符合条件则返回1条数据select*fromsummer_......
  • MySQL存储引擎
    MySQL的存储引擎存储引擎简介1.文件系统-操作系统组织和存储数据的一种机制-文件系统是一种软件2.文件系统的类型:ext234,xfs数据不管使用什么文件系统,数据内......
  • mysql学习笔记 0816
    单表查询查询所有列:select*from表名;select*fromstudent;查询指定的列:selectid,`name`,age,genderfromstudent;selectid,`name`,agefromstudent;补充:......
  • 【2022-08-16】mysql基础知识(三)
    mysql基础知识(三)约束条件之主键作用:1、单从约束条件上而言主键相当于notnull+unique(非空且唯一)2、主键的功能目前简单的理解为能够加快数据的查询速度,相当于字......
  • MySQL
    今日内容约束条件之外键外键前戏需要创建一张员工表 id name gender dep_name dep_desc上述表的缺陷 1.表结构不清晰到底是员工表还是部门表(不严重无所谓) 2.字......
  • MySQL多表查询
    多表连接的方式有四种:内连接外连接**全连接子查询SQL92语法1992年的语法。--查询学号,姓名,年龄,分数,通过多表连接查询,student和scores通过id和s_id连接SELECT st......