01、MySQL中null值的一个小坑 今天在测试null值的时候,发现了一个小问题,记录在这里,不知道大家以前遇到过没。...事情发展是这样的,在过滤一个表中的数值的时候,需要把age=2的列给剔除掉,然后查看剩余的列信息,这个操作看起来比较简单,我用一个表模拟一下过程: CREATE TABLE `test` ( `id...,而age字段没有添加这个约束,然后我们先插入一部分数据,如下: mysql:yeyztest 23:32:57>>select * from test; +----+------+-------+ |...其实这个问题,在之前的4月29号的文章中有说到过,就是在一条数据记录里面,null值字段和一般的字段是不在一起存储的,null值字段是存储在null值列表里面的。...所以造成了检索时候不匹配的现象,这个还是比较重要的一个点,希望对大家有用。 声明一下,测试环境是5.7.16版本的MySQL。
excelperfect 在下图1所示的工作簿Data.xlsx的工作表Sheet1中,存放着待使用的数据。 ?...图1 在下图2所示的工作簿GetData.xlsm中,根据列C中的数据,在上图1的工作簿Data.xlsx的列E中查找是否存在相应数据的单元格。 ?...图2 然后,将Data.xlsx中对应行的列I至列K单元格中的数据复制到GetData.xlsm相应的单元格中,如下图3所示。 ?... 3 Then MsgBox ("请选择列C中的单元格或单元格区域.")...Exit Sub Else '遍历所选的单元格 For Each rng In Selection '在数据工作表中查找相应的值所在的单元格
有时候,一行数据中前面的数据值都是0,从某列开始就是大于0的数值,我们需要知道首先出现大于0的数值所在的单元格。...例如下图1所示,每行数据中非零值出现的位置不同,我们想知道非零值出现的单元格对应的列标题,即第3行中的数据值。 ?...图2 在公式中, MATCH(TRUE,B4:M40,0) 通过B4:M4与0值比较,得到一个TRUE/FALSE值的数组,其中第一个出现的TRUE值就是对应的非零值,MATCH函数返回其相对应的位置...MATCH函数的查找结果再加上1,是因为我们查找的单元格区域不是从列A开始,而是从列B开始的。...ADDRESS函数中的第一个参数值3代表标题行第3行,将3和MATCH函数返回的结果传递给ADDRESS函数返回非零值对应的标题行所在的单元格地址。
SQL FOREIGN KEY 约束 SQL FOREIGN KEY 约束用于防止破坏表之间关系的操作。FOREIGN KEY 是一张表中的字段(或字段集合),它引用另一张表中的主键。...FOREIGN KEY 约束防止将无效数据插入到外键列中,因为它必须是父表中包含的值之一。...SQL CHECK 约束 SQL CHECK 约束用于限制可以放入列中的值范围。如果在列上定义了 CHECK 约束,它将仅允许为该列指定某些值。...如果在表上定义了 CHECK 约束,它可以基于行中其他列的值来限制某些列中的值。...SQL DEFAULT 约束 SQL DEFAULT 约束用于为列设置默认值。如果没有指定其他值,将在所有新记录中添加默认值。
SQL NOT NULL 约束SQL NOT NULL 约束用于强制确保列不接受 NULL 值。这意味着该字段始终包含一个值,而不允许插入新记录或更新记录时不提供此字段的值。...SQL UNIQUE 约束SQL UNIQUE 约束确保列中的所有值都是不同的。UNIQUE 和 PRIMARY KEY 约束都为列或一组列提供了唯一性的保证。...UNIQUE 约束,以确保列中的数据唯一性。...SQL PRIMARY KEY 约束SQL PRIMARY KEY 约束唯一标识表中的每条记录。主键必须包含唯一的值,并且不能包含 NULL 值。...一个表只能有一个主键;在表中,这个主键可以由单个列(字段)或多个列(字段)组成。
2.分类 根据约束数据列的限制, 约束可分为: 单列约束:每个约束只约束一列(字段) 多列约束:每个约束可约束多列数据 根据约束的作用范围,约束可分为: 列级约束:只能作用在一个列上,跟在列的定义后面...表级约束:可以作用在多个列上,不与列一起,而是单独定义 根据约束所起的作用,约束可分为: 主键约束 主键约束确保表中的每一行都具有唯一标识符,能够唯一标识该表中的每条记录。...外键约束 外键约束用于建立表与表之间的关系,确保引用另一个表中的值时的完整性。 外键约束经常和主键约束一起使用,用来确保数据的完整性,即保证该字段的值必须来自于主表的关联列的值。...在从表添加外键约束,用于引用主表中某列的值。 例如,在员工信息表中,员工所属部门是一个外键,因为该字段是部门表的主键。...MySQL 为另一个生成一个名称。 创建默认值约束 建表时在字段后使用 DEFAULT 添加默认值可创建默认值约束。
唯一索引确保索引中的值是唯一的,不允许有重复值。...table_name: 指定要修改的表的名称。ADD CONSTRAINT: 这是用于添加约束(包括唯一索引)的关键字。index_name: 指定要创建的唯一索引的名称。约束名称在表中必须是唯一的。...请注意,如果表中已经有重复的 email 值,那么添加唯一索引将会失败。在创建唯一索引之前,你可能需要确保表中的 email 列没有重复的值。...你可以指定一个或多个列作为索引的组合。这些列的数据类型通常是数值、文本或日期。CONSTRAINT: 用于添加约束的关键字。index_name: 指定要创建的唯一索引的名称。...尝试以下实例删除索引:mysql> ALTER TABLE testalter_tbl DROP INDEX c;四、使用 ALTER 命令添加和删除主键主键作用于列上(可以一个列或多个列联合主键),添加主键索引时
唯一索引:确保索引列的值都是唯一的,但允许有空值。 主键索引:特殊的唯一索引,不允许有空值。一个表只能有一个主键。...组合索引:多个列上的索引,搜索条件必须使用到组合索引中的第一个列,才能利用到索引。 索引的排序方法: 索引默认是按照升序(ASC)进行排序的。但也可以在创建索引时明确指定排序方向。...约束(Constraints) MySQL的约束是一种规则,用于限制表中的数据以确保数据的准确性和可靠性。约束可以在创建表时定义,也可以在表创建后添加。...一个表的外键列的值必须引用另一个表的主键或唯一键的值。 示例:创建一个名为orders的表,其中的student_id列引用students表的id列。...5、CHECK 约束 确保某列的值满足指定的条件。需要注意的是,虽然MySQL支持CHECK约束的语法,但在某些存储引擎(如InnoDB)中,它们不会强制执行。
(2)域完整性:是指表中的列必须满足某种特定的数据类型约束,其中约束又包括取值范围、精度等规定。...定义:主键–唯一标识一条记录,不能有重复的,不允许为空 外键–表的外键是另一表的主键,外键可以有重复的,可以是空值 索引–该字段没有重复值,但可以有一个空值 作用:主键–用来保证数据完整性 外键–用来和其他表建立联系用的...(1)非相关子查询是独立于外部查询的子查询,子查询总共执行一次,执行完毕后将值传递给外部查询。 (2)相关子查询的执行依赖于外部查询的数据,外部查询执行一行,子查询就执行一次。...区别: char (M) 类型的数据列里,每个值都占用 M 个字节,如果某个长度小于 M,MySQL 就会在它的右边用空格字符补足。(在检索操作中那些填补出来的空格字符将被去掉)。...varchar (M) 类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为 L+1 字节)。 Mysql 的存储引擎,myisam 和 innodb 的区别。
(2)域完整性:是指表中的列必须满足某种特定的数据类型约束,其中约束又包括取值范围、精度等规定。...主键、外键和索引的区别 定义: 主键–唯一标识一条记录,不能有重复的,不允许为空 外键–表的外键是另一表的主键, 外键可以有重复的, 可以是空值 索引–该字段没有重复值,但可以有一个空值...区别: char(M)类型的数据列里,每个值都占用M个字节,如果某个长度小于M,MySQL就会在它的右边用空格字符补足。(在检索操作中那些填补出来的空格字符将被去掉)。...varchar(M)类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节)。 16.Mysql 的存储引擎,myisam和innodb的区别。...(2) 选择合适的表字段数据类型和存储引擎,适当的添加索引。 (3) 做mysql主从复制读写分离。 (4)对数据表进行分表,减少单表中的数据量提高查询速度。
,使该字段不能有重复的值出现 同一个表可以有多个唯一约束 唯一约束可以是某个列,也可以多个列组合的唯一 唯一的字段可以为空的 在创建约束的时候,如果不给约束命名的话,那么默认和该列的名字相同。...如果是多个列的组合,那么默认的名字就是第一个字段的名字 MySQL会给唯一约束的列默认创建一个唯一索引 创建表的时候进行添加约束: sqlCREATE TABLE student2( sno VARCHAR...主键约束的列不允许重复,也不允许出现空值 一个表最多有一个主键约束,建立主键约束可以在列级别创建,也可以在表级别创建 主键约束对应表中的一列或者多列(复合主键) MySQL的主键名总是PRIMARY,自己命名了也没有用...在阿里开发规范中:不得使用外键约束与级联,一切外键概念必须在应用层解决 CHECK约束 检查模字段的值是否复合要求 MySQL5.7可以支持该约束,但是不起作用。...但是在MySQL8.0中就可以使用check约束了 DEFAULT约束 指定某个字段默认值,意思就是当该字段没有插入数据的时候,使用默认值 就是在后面加上default
、主键约束噢~ ---- 唯一约束 定义 唯一约束用于保证数据表中字段的唯一性,即表中字段的值不能重复出现。...语法如下: #列级约束 字段名 数据类型 unique; #表级约束 unique(字段名1,字段名2…); 列级约束定义在一个列上,只对该列起约束作用。...表级约束是独立于列的定义,可以应用在一个表的多个列上。...创建复合唯一约束 在表级唯一性约束创建时,unique()的字段列表中,可以添加多个字段,组成复合唯一键,特点是只有多个字段的值相同时才视为重复记录。...主键约束 定义 在MySQL中,为了快速查找表中的某条信息,可以通过设置主键实现。主键可以唯一标识表中的记录。
另一方面,为了使 MySQL 客户端更容易地使用 TIMESTAMP 列,服务器报告这样的列被赋值为 NULL 值(这是真的),即使 TIMESTAMP 实际上决不会包含一个 NULL 值。...157 158 PRIMARY KEY 是一个唯一 KEY,它还有一个额外的约束,所有键列必须被定义为 NOT NULL。在 MySQL 中,该被命名为 PRIMARY。...这在任何方面都不影响你如何使用该列;在 MySQL 中,VARCHAR 只是存储字符的另一个不同的方法。MySQL 执行这个转换,是因为它节省空间,并且使表操作更快。...例如,如果你尝试将一个 VARCHAR 列更改为 CHAR,而如果在这个表中包含其它的变长列,MySQL 将仍然使用 VARCHAR。...如果你移除一个AUTO_INCREMENT 列,并添加另一个 AUTO_INCREMENT 列,值将再次从 1 开始。 389 390 查看章节 A.6.1 ALTER TABLE 的问题。
如果从表中删除某一行,其主键值不分配给新行。 外键约束 外键是表中的一列,其值必须列在另一表的主键中。外键是保证引用完整性的极其重要部分。...提示:外键有助防止意外删除,除帮助保证引用完整性外,外键还有另一个重要作用。在定义外键后,DBMS 不允许删除在另一个表中具有关联行的行。例如,不能删除关联订单的顾客。...❑ 表可包含多个唯一约束,但每个表只允许一个主键。 ❑ 唯一约束列可包含 NULL 值。 ❑ 唯一约束列可修改或更新。 ❑ 唯一约束列的值可重复使用。...检查约束 检查约束用来保证一列(或一组列)中的数据满足一组指定的条件。检查约束的常见用途有以下几点。 ❑ 检查最小或最大值。例如,防止 0 个物品的订单(即使 0 是合法的数)。 ❑ 指定范围。...使用 ALTER 命令删除索引 主键作用于列上(可以一个列或多个列联合主键),添加主键索引时,你需要确保该主键默认不为空(NOT NULL)。
约束的分类 非空约束 关键字 NOT NULL 特点 默认,所有的类型的值都可以是NULL,包括INT、FLOAT等数据类型 非空约束只能出现在表对象的列上,只能某个列单独限定非空,不能组合非空...一个表可以有很多列都分别限定了非空 空字符串''不等于NULL,0也不等于NULL 添加非空约束 CREATE TABLE 表名称( 字段名 数据类型, 字段名 数据类型 NOT NULL...唯一约束可以是某一个列的值唯一,也可以多个列组合的值唯一。 唯一性约束允许列值为空。在创建唯一约束的时候, 如果不给唯一约束命名,就默认和列名相同。...MySQL会给唯一约束的列上默认创建一个唯一索引。 添加唯一约束 举例: 删除唯一约束 添加唯一性约束的列上也会自动创建唯一索引。 删除唯一约束只能通过删除唯一索引的方式删除。...删除时需要指定唯一索引名,唯一索引名就和唯一约束名一样。 如果创建唯一约束时未指定名称,如果是单列,就默认和列名相同;如果是组合列,那么默认和()中排在第一个的列名相同。也可以自定义唯一性约束名。
D、自定义完整性:用户自己定义的业务规则,比如使用触发器实现自定义业务规则。 ? 2、数据完整性实现方式 ? MySQL不支持Check约束,虽然可以在列上添加check约束,但不起作用。...B、唯一值约束:一张表可以有多个列添加唯一值约束,一直允许一条记录为空值。 实体完整性,由主键和唯一性约束来实现,确保表中记录有一列唯一标识。...MyISAM类型的存储引擎不会在主键列上创建索引,表中记录的存储顺序与插入顺序相同。 ? InnoDB存储引擎会自动在主键列上创建索引,插入的记录会根据主键的值的顺序排放。...可以在数据数据类型整数型的列上添加自增主键。 ?...table score add CONSTRAINT uc_sname UNIQUE(sname); 如果表中现有记录有重复值,不允许添加唯一性约束。
SELECT INTO 语句可用于通过另一种模式创建一个新的空表。...我们可以从一个表中复制所有的列插入到另一个已存在的表中: INSERT INTO table2 SELECT * FROM table1; 或者我们可以只复制希望的列插入到另一个已存在的表中: INSERT...在 SQL 中,我们有如下约束: NOT NULL - 指示某列不能存储 NULL 值。 UNIQUE - 保证某列的每行必须有唯一的值。...FOREIGN KEY - 保证一个表中的数据匹配另一个表中的值的参照完整性。 CHECK - 保证列中的值符合指定的条件。 DEFAULT - 规定没有给列赋值时的默认值。...KEY 约束 一个表中的 FOREIGN KEY 指向另一个表中的 UNIQUE KEY(唯一约束的键)。
图片简介MySQL 唯一约束(Unique Key)是指所有记录中字段的值不能重复出现。MySQL中的唯一约束是一种用于确保表中某列或多列的取值唯一的数据库约束。...唯一约束是一种用于限制数据库表中某列或多列取值的约束,确保这些列中的值各不相同。在定义了唯一约束的列上,数据库系统会自动检查插入或更新操作,确保数据的唯一性。...唯一约束和主键的区别在MySQL中,唯一约束和主键是两种不同的约束类型,但它们都用于确保数据的唯一性。两者之间的区别如下:主键:主键是一种特殊的唯一约束,它要求列中的值唯一且不允许为空。...一张表只能有一个主键,它在表中起到唯一标识每一行记录的作用。唯一约束:唯一约束要求列中的值唯一,但允许为空。一张表可以有多个唯一约束,用于保证不同列或组合的值唯一。...总结唯一约束是MySQL中确保表中列值唯一性的重要手段。它能够防止数据重复,加速查询操作,同时在一些情况下也可以用来替代主键。
分类 根据约束数据列的限制,约束可分为: 单列约束:每个约束只约束一列 多列约束:每个约束可约束多列数据 根据约束的作用范围,约束可分为: 列级约束:只能作用在一个列上,跟在列的定义后面 表级约束:...NULL,包括INT、FLOAT等数据类型 非空约束只能出现在表对象的列上,只能某个列单独限定非空,不能组合非空 一个表可以有很多列都分别限定了非空 空字符串''不等于NULL,0也不等于NULL 添加非空约束...MySQL会给唯一约束的列上默认创建一个唯一索引。...); 删除唯一约束 添加唯一性约束的列上也会自动创建唯一索引。...主键约束对应着表中的一列或者多列(复合主键) 如果是多列组合的复合主键约束,那么这些列都不允许为空值,并且组合的值不允许重复。 MySQL的主键名总是PRIMARY,就算自己命名了主键约束名也没用。
【数据库】MySQL进阶二、索引简易教程 Mysql索引简易教程 基本概念 索引是指把你设置为索引的字段A的内容储存在一个独立区间S里,里面只有这个字段的内容。...一般来说,应该在这些列 上创建索引,例如: 在经常需要搜索的列上,可以加快搜索的速度; 在作为主键的列上,强制该列的唯一性和组织表中数据的排列结构; 在经常用在连接的列上,这 些列主要是一些外键,可以加快连接的速度...唯一性索引保证在索引列中的全部数据是唯一的,不会包含冗余数据。如果表中已经有一个主键约束或者唯一性键约束,那么当创建表或者修改表时,SQL Server自动创建一个唯一性索引。...;每当使用插入语句插入数据或者使用修改语句修改数据时,SQL Server检查数据的冗余性:如果有冗余值,那么SQL Server取消该语句的执行,并且返回一个错误消息; 确保表中的每一行数据都有一个唯一值...; 为了使查询优化器使用复合索引,查询语句中的WHERE子句必须参考复合索引中第一个列;当表中有多个关键列时,复合索引是非常有用的;使用复合索引可以提高查询性能,减少在一个表中所创建的索引数量。
领取专属 10元无门槛券
手把手带您无忧上云