首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mysql约束、分组查询

tip: 通过 desc 表命令查看当前表信息 tip2: as 关键字可以为我们的字段或者表取别名 Mysql约束 顾名思义就是对表中的数据进行限定, 目的是保证数据的正确性, 有效性和完整性 主键约束...NOT NULL 只能约束程序层面上没有操作该表中的某个字段, 不能约束人行为上对其赋值为空白字符....唯一约束 UNIQUE NULL可以重复 比如统计店铺业绩, 该店铺不可以重复, 那就可以使用唯一约束 外键约束foreign key 外键的作用 保持数据的一致性和完整性, 通过外键来表达主表和从表的关系...维护成本 需要有专业DBA来维护庞大的数据库关系 default 默认约束, 默认会填充当前字段....如果我们没有给一个有默认约束的字段create_time值, 那么该字段会默认填充CURRENT_TIMESTAMP 分组查询GROUP BY 将数据按某个字段进行分组, 配合SUM, AVG, COUNT

3.7K30

MySQL】SQL语句查询约束、备份与恢复

SQL语句查询 排序 通过order by语句,可以将查询出的结果排序。放置在select语句的最后。...格式: SELECT * FROM 表 ORDER BY 排序字段 ASC|DESC; ASC 升序 (默认) DESC 降序 题干: #1.使用价格排序(降序) #2.在价格排序(升序)的基础上,以...关键字:group by 格式: SELECT 字段1,字段2… FROM 表GROUP BY分组字段 HAVING 条件; 分组操作中的having子语句,是用于在分组后对数据进行过滤的,作用有点像...by page having page>18; -- 小技巧, 统计出每种XX有多少个  查询就按照XX进行分组  ==> select XX ,count(XX) from 表 group by...8)查询英语成绩大于90分的同学信息 9)查询总分大于200分的所有同学信息 11)查询数学分数为89 90 91 的同学信息 13)查询数学分高于80并且语文分高于82的同学信息 14)查询英语80

1.9K20
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL 约束

); 创建检查约束MySQL 8.0.16 之前,CREATE TABLE 仅允许以下有限版本的表 CHECK 约束语法,该语法将被解析并忽略: CHECK (expr) 从 MySQL 8.0.16...如果省略,MySQL 会根据表、_chk_ 和序数 (1, 2, 3, …) 生成一个名称。约束名称的最大长度为 64 个字符。 它们区分大小写,但不区分重音符号。...的 information_schema 数据库里的 table_constraints 表保存了该数据库实例中所有的约束信息,用户可以通过查询该表获取该数据库的约束信息。...在 MySQL 中,通常情况下,这个值通常为 def,因为 MySQL 不使用目录的概念。 CONSTRAINT_SCHEMA:这是包含约束的数据库的名称。它指定了约束所属的数据库。...5.删除约束 要删除 MySQL 表中的约束,可以使用 ALTER TABLE 语句并指定要删除的约束类型和名称。

17010

MySQL约束

varchar(25) unique -- 给id_number设置唯一约束 - ); 查看唯一约束:show index from 表; 删除唯一约束:alter table 表 drop index...字段名; 创建表之后添加唯一约束:alter table 表 modify 字段名 数据类型 unique; 主键约束 (primary key 同时保证了唯一和非空) - 创建表时添加主键约束...表 drop primary key; 添加主键约束:alter table 表 modify 字段名 数据类型 primary key; 自动增长 (auto_increment) 一个表中有且只能有一个自增长列...外键约束 (foreign key , 让多个表之间关联,从而保证数据的正确性) - 创建表时添加外键约束: - 删除键外键约束:alter table 表 drop foreign key 外键名称...; - 添加外键:alter table 表 add [constraint 外键名称] foreign key (外键字段名称) references 关联的主表(字段名); * 注:外键名称可以不指定

1.6K20

MySQL 约束介绍

唯一性约束允许列值为空。 在创建唯一约束的时候,如果不给唯一约束命名,就默认和列名相同。 MySQL会给唯一约束的列上默认创建一个唯一索引。...字段名 数据类型; 5、外键约束 限定某个表的某个字段的引用完整性 从表的外键列,必须引用/参考主表的主键或唯一约束的列 在创建外键约束时,如果不给外键约束命名,默认不是列名,而是自动产生一个外键名...(例如student_ibfk_1;),也可以指定外键约束。...从表”中指定外键约束,并且一个表可以建立多个外键约束 当创建外键约束时,系统默认会在所在的列上建立对应的普通索引,索引是外键的约束,删除外键约束后,必须手动删除对应的索引 CREATE TABLE...>] FOREIGN KEY(从表的某个字段) REFERENCES 主表(被参考字段) ); #(从表的某个字段)的数据类型必须与主表(被参考字段)的数据类型一致,逻辑意义也一样 #(从表的某个字段

1.6K41

mysql约束

mysql设计表中,有个概念叫做约束 什么是约束 约束英文:constraint 约束实际上就是表中数据的限制条件 约束种类 mysql约束大概分为以下几种: 非空约束(not null) 唯一性约束...(unique) 主键约束(primary key) PK 外键约束(foreign key) FK 检查约束(目前MySQL不支持、Oracle支持,本文不做介绍) 为了能继续看下去,打开mysql,...(非空约束,主键约束,唯一性约束);在后面会使用到外键约束 非空约束 非空约束是我们最常见的一种约束方式,它规定了我们插入数据不允许为空(在mysql中,''不是空,null才是),例如以下插入语句:...应用场景方面,例如用户邮箱,用户密码不能为空,都可以增加非空约束 唯一性约束 唯一性约束是使用unique关键字进行的约束,它有多种约束方式以及约束形式....表:子表 创建先创建父表 删除先删除子表数据 插入先插入父表数据 外键约束将会让mysql在插入,删除,更新会增加额外的判断,严格来说,不允许使用外键约束,如果需要限制,请在代码层限制

2.1K10

Mysql外键约束

外键是用来实现参照完整性的,不同的外键约束方式将可以使两张表紧密的结合起来,特别是修改或者删除的级联操作将使得日常的维护工作更加轻松。...外键主要用来保证数据的完整性和一致性 两个表必须是InnoDB表,MyISAM表暂时不支持外键 外键列必须建立了索引,MySQL 4.1.2以后的版本在建立外键时会自动创建索引,但如果在较早的版本则需要显示建立...如果父表试图UPDATE或者DELETE任何子表中存在或匹配的外键值,最终动作取决于外键约束定义中的ON UPDATE和ON DELETE选项。...外键约束使用最多的两种情况: 1)父表更新时子表也更新,父表删除时如果子表有匹配的项,删除失败; 2)父表更新时子表也更新,父表删除时子表匹配的项也删除。...`article`, CONSTRAINT `fk_1` FOREIGN KEY (`category_id`) REFERENCES `category` (`id`)) (4)更改更新删除约束

5.8K81

MySQL约束详接

为了保证数据的完整性,SQL规范以约束的方式对表数据进行额外的条件限制。 从以下四个方面考虑: 什么是约束 约束是表级的强制规定。...唯一约束可以是某一个列的值唯一,也可以多个列组合的值唯一。 唯一性约束允许列值为空。在创建唯一约束的时候, 如果不给唯一约束命名,就默认和列名相同。...MySQL会给唯一约束的列上默认创建一个唯一索引。 添加唯一约束 举例:    删除唯一约束 添加唯一性约束的列上也会自动创建唯一索引。 删除唯一约束只能通过删除唯一索引的方式删除。...删除时需要指定唯一索引,唯一索引就和唯一约束一样。 如果创建唯一约束时未指定名称,如果是单列,就默认和列名相同;如果是组合列,那么默认和()中排在第一个的列名相同。也可以自定义唯一性约束。... 建表后 alter table 表名称 modify 字段名 数据类型 auto_increment;  MySQL 8.0将自增主键的计数器持久化到重做日志中。

1.8K10

MySQL】:约束全解析

本文将深入介绍MySQL中的各种约束类型及其使用方法,包括非空约束、唯一约束、主键约束、默认约束、检查约束和外键约束,以及如何在创建表和修改表时添加约束,以及外键约束的相关知识。 一....3.2 语法 添加外键 CREATE TABLE 表( 字段名 数据类型, ......KEY (外键字段名)REFERENCES 主表 (主表列名) ; 删除外键 ALTER TABLE 表 DROP FOREIGN KEY 外键名称; 3.3 删除/更新行为 添加了外键之后,再删除父表数据时产生的约束行为...SET DEFAULT 父表有变更时,子表将外键列设置成一个默认的值 (Innodb不支持) 具体语法为: ALTER TABLE 表 ADD CONSTRAINT 外键名称 FOREIGN KEY...(外键字段) REFERENCES 主表 (主表字段名) ON UPDATE CASCADE ON DELETE CASCADE; ️全篇总结 本文详细介绍了MySQL中的各种约束类型及其语法,包括约束的概念

16310

MySql】表的约束

概述 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的。...表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。约束的本质是通过技术收到逼迫程序员插入正确的数据,反过来,站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。...约束的最终目标:保证数据的完整性和可预期性所以需要更多的约束。...' 删除主键 alter table 表 drop primary key; 当表创建好以后但是没有主键的时候,可以再次追加主键 alter table 表 add primary key(字段列表...建立外键的本质其实就是把相关性交给mysql去审核了,提前告诉mysql表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入。

17130

MYSQL】表的约束

前言 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的。...1.当表创建好以后但是没有主键的时候,可以再次追加主键 alter table 表 add primary key(字段列表) 案例: create table stu2( id int comment...'学号', name varchar(5) ); 创建好表之后,我们可以追加主键 2.删除主键 alter table 表 drop primary key; 案例: 3.复合主键 在创建表的时候...,主表则必须是有主键约束或unique约束。...//创建班级表 create table class( id int primary key comment '班号', name varchar(10) comment '班级'  );

21740

MySQL】表的约束

反过来,在 mysql 角度,凡是插入进来的数据,都是符合数据约束的!约束的最终目的就是保证数据的完整性和可预期性。因此我们需要更多的约束条件!...null(不为空) 数据库默认字段基本都是字段为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运算,任何数与 null 相加都为 null,如下: 假设我们需要创建一个班级表,包含班级和班级所在的教室...null ); 下面我们查看表结构,我们可以看到 Null 列的内容为 NO,即插入的数据不能为空: 接下来我们插入几组数据测试: 我们可以看到,当班级或者教室其中一个为空都不能插入。...: alter table 表 add primary key(字段列表) 再为上表添加主键: 注意,一张表中最多只有一个主键,不意味着一个表的主键,只能添加给一列!...建立外键的本质其实就是把相关性交给 mysql 去审核了,提前告诉 mysql 表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql 不允许你插入。

10410

MySQL表的约束

一.表的约束的概念 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。...所谓约束,就是避免犯一些低级错误,比如类似于语法错误,编译器的编译失败实际上也算是一种约束。 表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。...约束的本质: 通过技术手段倒逼程序员插入正确的数据。反过来站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。 约束的最终目标: 保证数据的完整性和可预期性。 为什么数据库这么严格?...二.表的非空约束 1.NULL与’ '比较 在MySQL数据类型已经说过,这二者是不同的,NULL代表什么都没有,而' '代表一个空串。 在select语句中,NULL不会参与到相应的计算操作中。...在两个表的前提下,若要新增一学生信息,只需要插入三个字段;若合并成一个表,那么就需要插入3+2-1=4个字段,并且我们知道组合起来的情况也会更多,两个表合并的结果就是数据位置上的相乘,比如: 两个表

18450
领券