mysql的约束和表关系

根据查询的结果,复制出一个新表

create table newTable AS select * from oldTable;

create table newPeople  AS select * from day2_test.people;

 

约束

引入:如果某一列如id列,有重复的数据,无法准确定位,有的列有空值null;

解决:需要给列约束,让数据合法

约束其实就是一种限制,用于修饰表中的列,通过这种限制来保证数据的准确性,有效性和完整性

约束名称关键字作用
主键约束primary key唯一+非空
唯一约束unique唯一
非空约束not null非空
默认值约束default 默认的值指定默认值
外键约束foreign key多表之间的关系约束

 主键约束

主键概述:设定表中某一字段,那么该字段所在列的数据能够唯一的标识表中每一行数据(作用)

设定为主键的字段一般和业务无关列有这些特点:1:唯一,2:非空,3:与业务无关

 主键的定义和删除语法

        1在建表的时候指定

create table 表名 (id int primary key,其他字段...);

        2在已有表中指定(原来表中没有主键) 

 alter table 表名 add primary key(字段名);

         3删除主键约束

alter table 表名 drop primary key;

-- 在已有表中添加索引
alter table people add primary key (id);-- 创建的时候添加
create table student2
(id int primary key,name varchar(10)
);
-- 删除主键约束
alter table student2 drop primary key;

 练习

create table student3
(id int primary key,name varchar(10),age int
);
-- 测试主键
insert into student3 values(1,'hhh',18);
insert into student3 values(1,'aaa',20);-- err
insert into student3 values(null,'ccc',56);-- err-- 删除主键
alter table student3 drop primary key ;-- 添加主键
alter table student3 add primary key (id);

主键列下数据不能重复

索引我们把主键列交给mysql(主键列的插入的数据,交给mysql管理)

主键自增:
主键如果让我们自己添加可能有重复的主键导致数据添加失败。所以我们每次插入新的记录时,数据库都是自己生成主键的值

        主键添加语法:

字段名 字段类型 primary key auto_increment;

注意,需要让主键自增,主键必须是整数类型

 

create table student4
(id int primary key auto_increment,-- 主键自动增加name varchar(10)
);insert into student4(name) values('aaa');
insert into student4(name) values('bbb');
insert into student4(name) values('ccc');
insert into student4 (id, name) values (null,'ddd');delete from student4 where id=3;-- 把第三行删除insert into student4(name) values('eee');-- id=5,可见把id=3删除后,之后生成的id不会重复insert into student4(id, name) values(100,'fff');--  使用100覆盖mysql管理的主键值
insert into student4(name) values('ggg'); -- id=101select * from student4;

        主键自增的注意事项

1.主键列下的数据由mysql维护(从1开始,每次增加1)

2.mysql维护过的主键值,不能重复使用

3.当程序员干预主键,就会拿插入的主键值,覆盖mysql管理的主键值 

        delete和truncate 删表对id的影响

1.delete删除表中的数据,不重复auto_increment的值

2.truncate摧毁表,重建表,auto_increment的值重置为1 

 唯一约束

一个表只能有一个主键 

作用

被唯一约束的字段,本列数据不允许出现重复的数据,null除外,null可以重复

 语法

1.create table 表名 (id int unique,字段名);

2.alter table 表名 add unique(字段名);

create table student5
(id int primary key auto_increment,name varchar(10)
);alter table student5 add unique (name);
-- 插入相同的name值时,会插入失败,但是id(主键值)还是会自增

 非空约束

 作用:

被非空约束的字段,本列数据不允许出现null数据。插入数据若为null就会报错

语法

1.create table 表名 (id int not null);

2.alter table 表名 modify 字段名 类型 not null;

create table student6
(id int primary key auto_increment,name varchar(10) unique not null
);alter table student5 modify name varchar(10) not null ;

 非空+唯一约束和主键约束的区别

1.主键约束在一张表只能存在一个,非空加唯一约束没有限制,可以存在多个

2.主键约束有自动增长,非空+唯一约束没有自动增长

默认值约束

作用

被默认值约束的字段(列),相当于给字端添加默认值,插入数据时如果字段没有被赋值,则使用默认值

语法

默认值约束需要使用的关键字:default

1.创建表时指定

create table 表名

(

字段名 字段类型 default 默认值,

其他字段

); 

2.给已有表指定字段添加默认值

alter table 表名 modify 字段名 字段类型 default 默认值;

create table student7
(id int primary key auto_increment,name varchar(10) not null unique,address varchar(10) default '天津'
);
-- 插入null值,不代表没有给数据
insert into student7 (id, name, address) values (null,'aaa',null);-- 没有给值
insert into student7 (name) values ('bbb');

 

表关系

 一对一

一对多

多对多

一对多表关系

例子:一个用户可以有多个订单,一个订单只能对应一个用于

我们约定,"一方"(用户表)叫主表或1表,"多方"(订单表)叫从表或多表 

设计表时,我们通常在多表中添加一个字段,用于存储主表主键的值,这个字段叫外键字段。

外键约束的作用:
1.建立表和表之间的关系

2.约束外键下的数据和主表数据下的数据保持一致(一致性,完整性)

多对多表关系

例子:老师和学生之间的关系

会创建第三张中间表(有两个字段,分别是学生和老师的主键),由中间表承担外键字段(降低多对多的复杂关系,变成两个一对多)

一是老师表和学生表,多是中间表

这个中间表中会有多个相同学生主键,和多个相同老师主键

所以一个学生对应多个相同的学生主键,一个学生主键对应一个学生

所以是一对多

 问题一:怎么建立表和表之间的关系

答案:外键字段+主键字段

问题二:外键字段应该创建在哪个表

外键字段创建,需要考虑多表关系

一对多:外键字段创建在多表上

多对多:创建第三张表,外键字段创建在中间表上

一对一:1.两张表合并为一张表

                2.(一定要外键字段)任选一张表为从表

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/3335.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

实体店引流客户的最快方法是什么?线上短视频+直播引流!

前言:为什么想到写这个话题?因为在每周三晚在视频号白杨SEO免费直播的问题解答的时候,有个朋友问同城流量怎么做?我就以实体店举例解答说了做推荐搜索流量相结合。我想应该还有一些朋友也想知道,所以就分享出来&#x…

组合总和(Lc39)——排序+剪枝+回溯

给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target ,找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 ,并以列表形式返回。你可以按 任意顺序 返回这些组合。 candidates 中的 同一个 数字可以 无限制重复被选取 。如…

python的练习

python 练习 一、练习题目二、代码概览 一、练习题目 Hello World 实例数字求和平方根二次方程计算三角形的面积计算圆的面积随机数生成摄氏温度转华氏温度交换变量if 语句判断字符串是否为数字判断奇数偶数判断闰年获取最大值函数质数判断输出指定范围内的素数阶乘实例九九乘…

MyBatis多参数查询解析

参考官网 1. 底层 底层是ParamNameResolver类查看getNameParams方法实现 2. 获取参数的两种方式 MyBatis获取参数值的两种方式: ${} : 本质就是字符串拼接#{} :本质就是占位符赋值 3. 多种情况的获取情况 单参数情况: a. 单参数-单个字面量类型 …

人脸清晰修复神器CodeFormer

随着AI技术在图像处理领域大展身手,AI去马赛克相关的项目也屡见不鲜,比如在Github上开源免费、备受欢迎的 CodeFormer 。不得不说利用这款神奇的人脸修复工具,真的是让我大开眼界,竟然可以这样搞! 不管面对的是多么模…

Java知识总结-基础

Java中的访问权限修饰符 Java语言有四个权限访问修饰符,权限从大到小依次为: 1)public :公共权限,可以被任意类访问,不同包不同类依然可以访问, 可修饰:类、成员变量、方法&#…

大模型+多模态实现

那么如何在预训练LLM的基础上引入跨模态的信息(包括图像、语音、视频模态),让其变得更强大、更通用呢?本节将介绍“大模型多模态”的3种实现方法。 以LLM为核心,调用其他多模态组件 微软亚洲研究院(MSRA&…

STM32中SPI通信的完整C语言代码范例

SPI (Serial Peripheral Interface) 是一种同步串行通信协议,广泛应用于嵌入式系统中,用于与外设进行数据交换。STM32系列微控制器提供了丰富的SPI外设,支持多种工作模式和配置选项。本文将以STM32F103系列为例,详细介绍SPI通信的…

Java基础(运算符)

运算符 运算符和表达式 运算符:对字面量或者变量进行操作的符号 表达式:用运算符把字面量或者变量连接起来,符合java语法的式子就可以称为表达式;不同运算符连接的表达式体现的是不同类型的表达式。 算术运算符(加…

Linux基础命令[24]-su

文章目录 1. su 命令说明2. su 命令语法3. su 命令示例3.1 不加参数3.2 -(登录)3.3 -c(执行命令) 4. 总结 1. su 命令说明 su:以用户身份执行命令,基本信息如下: Usage:su [options] [-] [USE…

一些RabbitMQ面试题

RabbitMQ是什么,它的主要用途是什么 RabbitMQ是一个开源的消息代理软件, 它实现了高级消息队列协议(AMQP), 主要用于在分布式系统之间进行可靠的异步通信。 它的主要用途包括解耦系统组件、提高系统可扩展性、实现消息…

数据结构四:线性表之带头结点的单向循环循环链表的设计

前面两篇介绍了线性表的顺序和链式存储结构,其中链式存储结构为单向链表(即一个方向的有限长度、不循环的链表),对于单链表,由于每个节点只存储了向后的结点的地址,到了尾巴结点就停止了向后链的操作。也就…

架构师系列-消息中间件(九)- RocketMQ 进阶(三)-消费端消息保障

5.2 消费端保障 5.2.1 注意幂等性 应用程序在使用RocketMQ进行消息消费时必须支持幂等消费,即同一个消息被消费多次和消费一次的结果一样,这一点在使用RoketMQ或者分析RocketMQ源代码之前再怎么强调也不为过。 “至少一次送达”的消息交付策略&#xff…

Hive主要介绍

Hive介绍 hive是基于 Hadoop平台操作 HDFS 文件的插件工具 可以将结构化的数据文件映射为一张数据库表 可以将 HQL 语句转换为 MapReduce 程序 1.hive 是由驱动器组成,驱动器主要由4个组件组成(解析器、编译器、优化器、执行器) 2.hive本身不…

什么是Java中的代理模式?

Java中的代理模式(Proxy Pattern)是一种设计模式,用于在不改变原始对象(也称为主题,Subject)的代码的情况下,为原始对象提供代理对象,以控制对原始对象的访问。代理模式可以在不改变…

libtorch c10::IValue类解析,从IValue获取值

0. 简介 c10::IValue像一个数据容器,但是它又不用来直接存储数据,只是一层数据的封装。 怎么理解呢?c10::IValue可以存储torchscript里很多类型的数据,比如c10::IValue存储可能是一个Tensor,一组Tensor,或…

【安卓13-Framework】SystemUI定制之屏蔽下拉状态栏部分快捷按钮

1、需求 屏蔽下拉状态栏谷歌录屏、省电模式、二维码扫描器等快捷按钮。 2、修改路径 普及:安卓的SystemUI包提供了状态栏、导航栏、通知中心等重要的用户界面元素。 状态栏小部件UI显示修改路径:frameworks/base/packages/SystemUI/src/com/android/s…

Java虚拟机(jvm)常见问题总结

1.电脑怎样认识我们编写的Java代码 首先先了解电脑是二进制的系统,他只认识 01010101比如我们经常要编写 HelloWord.java 电脑是怎么认识运行的HelloWord.java是我们程序员编写的,我们人可以认识,但是电脑不认识 Java文件编译的过程 1. 程…

git lab 2.7版本修改密码命令

1.gitlab-rails console -e production Ruby: ruby 2.7.5p203 (2021-11-24 revision f69aeb8314) [x86_64-linux] GitLab: 14.9.0-jh (51fb4a823f6) EE GitLab Shell: 13.24.0 PostgreSQL: 12.7 2根据用户名修改密码 user User.find_by(username: ‘username’) # 替换’use…

无人驾驶(移动机器人)路径规划之RRT与RRTStar算法及其matlab实现

在自动驾驶与移动机器人路径规划时,必定会用到经典的算法RRT与RRT Star。下面是RRT与RRTStar的matlab实现效果。可以发现RRTStar效果明显改善。 目录 一、效果比较 1.1 RRT算法效果(黑色为障碍物,红色线为最终路径,蓝色三角形为…