首页 > 数据库 >sql中限制条件 数据关系

sql中限制条件 数据关系

时间:2022-11-24 20:00:25浏览次数:37  
标签:限制 name int create sql 主键 条件 table id

今日内容总结

无符号、零填充

unsigned
	id int unsigened
zerofill
	if int(5) zerofill

非空

create table t1(
	id int,
    name varchar(16)
);
insert into t1(id) values(1);
insert into t1(name) values('xiaochen');
insert into t1(name,id) values('kevin',2);
ps:所有字段类型不加约束条件的情况下默认都可以为空 sql中的空为Null
    

create table t2(
	id int,
    name varchar(16) not null
);
'''字段名后面加上 not null 就可以限制不可不输入(空字符不算空)'''
insert into t2(id) values(1);	    #>>>结果报错 字段name为空
insert into t2(name) values('aaa');	#>>>结果id为null 数据存入
insert into t2 values(1,'');	    #>>>什么都不输入也行
insert into t2 values(2,null);		#>>>报错 null是一个关键字

默认值

create table t3(
	id int,
   	sex varchar(16) default '男'
);
此时如果不传入值 就可以取我们设置的默认值
insert into t3(id) values(1);
# 结果
id	sex
1	男(取默认值)
'''
我们也可以通过插入数据值来正常填写数据
'''

唯一值

#单列唯一
create table t4(
	id int unique,
    name varchar(32) unique
);
加上unique可以限制插入数据的时候不可以和插入已经有(单列里)的数据
insert into t4 values(1,'aaa'),(2,'aaa')  # 报错 'aaa'已存在

#多列唯一
create table t5(
	id int,
    ip varchar(32),
    port int,
    unique(ip,port)
 );
往unique里写入字段名 可以将字段名绑定在一起 然后判断是否有重复
insert into t5 values(1,'127.0.0.1',8080),(2,'127.0.0.1',8081),(3,'127.0.0.2',8080); #不会报错
insert into t5 values(4,'127.0.0.1',8080); 
#报错 已经存在数据:'127.0.0.1',8080

主键

#在创建表的时候 主键是不可不写的
#InnoDB存储引擎规定了所有的表都必须有且只有一个主键
那在之前的编写时候为什么可以不设置主键呢?(小声bb)
	'''
	原因:当表中没有主键也没有其他非空且唯一的字段的情况下
	InnoDB会采用一个隐藏的字段作为表的主键 
	隐藏意味着无法使用 基于该表的数据查询只能一行行查找 速度很慢
	'''
#设立主键的作用
	主键是组织数据的重要条件并且主键可以加快数据的查询速度
#主键的特性
	1.单从约束层面上而言主键相当于not null + nuique(非空且唯一)
 	2.当表中没有设置主键但是有其他非空且唯一的字段 那么会从上往下将第一个字段升级为主键
#设定主键
	1.create table t6(
    	id int primary key
    );
    2.create table t7(
        id int,
        age int not null unique,
        phone bigint not null unique,
        birth int not null unique,
        height int not null unique
        );
    age会升级为主键
'''
我们在创建表的时候应该有一个字段用来标识数据的唯一性 并且该字段通常情况下就是'id'(编号)字段
	id nid sid pid gid uid
'''

自增

设想>>>:假设我们在填入数据的时候一下不记得id填到多少号了怎么办?
    
# 自增 
	我们可以将id字段下的数据设立为自增 这样就可以使字段自增不需要输入 该约束条件不能单独出现 并且一张表只能出现一次 主要就是配合主键一起作用
    
create table t8(
	id int primary key auto_increment
);
"""
自增特性
	自增不会因为数据的删除而回退 永远自增往前
	如果自己设置了更大的数 则之后按照更大的往前自增
	
	如果像重置某张表的主键值 可以使用
	truncate t9; 清空表数据并重置主键(格式化)
"""

外键前戏

我们需要制作一张表格
	id	name	age		dep_name	dep_desc
    
1.表语义不明确(到底是员工还是部门)
2.存储数据过于重复(浪费存储空间)
3.数据的拓展性极差

将上述的表格制作成两个表格
	id	name	age
    id	dep_name dep_desc
上述的三个问题都可以解决· 但是员工跟部门没有了关系

外键字段:用于表示数据与数据之间关系的字段

关系的判断

表关系、数据关系其实意思是一样的 知识说法上有区分

关系总共有四种
	一对多
    多对多
    一对一
    没有关系
    
关系的判断可以采用'换位思考'原则

一对多关系

以员工表和部门表为例
	#员工表的角度
    	自问:一名员工能否对应多个部门
    	答:不可以
    #再站在部门角度
    	自问:一个部门是否可以对应多个员工
    	答:可以
结论:一个可以一个不可以 那么关系就是'一对多'
针对'一对多'关系 外键字段应该建在'多'的一方

外键字段的建立

需注意:先定义出含有普通字段的表 之后再考虑有外键字段的添加
    
create table emp(
	id int primay key auto_increment,
    name varchar(32),
    age int,
    dep_id int,
    foreigh key(dep_id) references dep(id)
);

create table dep(
	id int primary key auto_increment,
    dep_name varchar(32),
    dep_desc varchar(64)
);

1.创建表的时候一定要先创建被关联表
2.录入表数据的时候一定要先录入被关联表
3.修改数据的时候外键字段无法修改和删除

针对3有简化措施>>>:级联更新级联删除
create table emp1(
	id int primary key auto_increment,
    name varchar(32),
    age int,
    dep_id int,
    foreigh 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(64)
);
'''
外键其实就是强耦合 不符合解耦合的特性
	所以很多时候 实际项目中当表较多的情况 我们可能不会使用外键 而是使用代码建立逻辑层面的关系
'''

多对多关系

以书籍表与作者表为例
	1.先站在书籍表的角度
    	问:一本书能否对应多个作者
     	答:可以
 	2.再站在作者表的角度
    	问:一个作者能不能出多本书
     	答:可以
结论:两个都可以 关系就是'多对多'
针对'多对多'不能直接再表中创建 需要新建第三张表专存对应的关系

create table book(
	id int primary key auto_increment,
 	title varchar(32),
  	price float(5,2)
);
create table author(
	id int primary key auto_increment,
 	name varchar(32),
  	phone bigint
);
create table book2author(
	id int primary key auto_increment,
   author_id int,
 	foreign key(author_id) references author(id)
  	on update cascade
  	on delete cascade,
   book_id int,
  	foreign key(book_id) references book(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,create,sql,主键,条件,table,id
From: https://www.cnblogs.com/xiaochenxiangchangpang/p/16923046.html

相关文章