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

mysql数据库的单表约束有哪些

MySQL数据库的单表约束主要包括以下几种:

1. 主键约束(PRIMARY KEY)

基础概念:主键约束用于唯一标识表中的每一行数据。一个表只能有一个主键,且主键的值必须是唯一的,不允许为空。

优势

  • 确保数据的唯一性和完整性。
  • 可以作为外键引用,用于建立表与表之间的关系。

应用场景

  • 用户表中的用户ID。
  • 订单表中的订单ID。

示例代码

代码语言:txt
复制
CREATE TABLE users (
    user_id INT PRIMARY KEY,
    username VARCHAR(50) NOT NULL,
    email VARCHAR(100) UNIQUE
);

2. 唯一约束(UNIQUE)

基础概念:唯一约束用于确保表中某一列或多列的值是唯一的,但允许为空值。

优势

  • 确保数据的唯一性。
  • 可以用于索引优化查询性能。

应用场景

  • 用户表中的电子邮件地址。
  • 产品表中的产品代码。

示例代码

代码语言:txt
复制
CREATE TABLE products (
    product_id INT PRIMARY KEY,
    product_code VARCHAR(20) UNIQUE,
    product_name VARCHAR(100) NOT NULL
);

3. 非空约束(NOT NULL)

基础概念:非空约束用于确保表中某一列的值不能为空。

优势

  • 确保数据的完整性。
  • 避免插入无效数据。

应用场景

  • 用户表中的用户名。
  • 订单表中的订单日期。

示例代码

代码语言:txt
复制
CREATE TABLE orders (
    order_id INT PRIMARY KEY,
    order_date DATE NOT NULL,
    customer_id INT
);

4. 外键约束(FOREIGN KEY)

基础概念:外键约束用于建立两个表之间的关系,确保引用完整性。

优势

  • 确保数据的引用完整性。
  • 维护表之间的关系。

应用场景

  • 订单表中的客户ID引用用户表中的用户ID。
  • 订单明细表中的订单ID引用订单表中的订单ID。

示例代码

代码语言:txt
复制
CREATE TABLE customers (
    customer_id INT PRIMARY KEY,
    customer_name VARCHAR(100) NOT NULL
);

CREATE TABLE orders (
    order_id INT PRIMARY KEY,
    order_date DATE NOT NULL,
    customer_id INT,
    FOREIGN KEY (customer_id) REFERENCES customers(customer_id)
);

5. 检查约束(CHECK)

基础概念:检查约束用于确保表中某一列的值满足特定的条件。

优势

  • 确保数据的合法性。
  • 避免插入不符合条件的数据。

应用场景

  • 用户表中的年龄必须在18到100之间。
  • 订单表中的订单金额必须大于0。

示例代码

代码语言:txt
复制
CREATE TABLE users (
    user_id INT PRIMARY KEY,
    username VARCHAR(50) NOT NULL,
    age INT CHECK (age BETWEEN 18 AND 100)
);

常见问题及解决方法

问题1:主键约束冲突

原因:尝试插入重复的主键值。

解决方法

  • 确保插入的数据在主键列上是唯一的。
  • 使用AUTO_INCREMENT自动生成唯一的主键值。

示例代码

代码语言:txt
复制
CREATE TABLE users (
    user_id INT AUTO_INCREMENT PRIMARY KEY,
    username VARCHAR(50) NOT NULL
);

问题2:外键约束冲突

原因:尝试插入的外键值在引用表中不存在。

解决方法

  • 确保插入的外键值在引用表中存在。
  • 先插入引用表中的数据,再插入外键表中的数据。

示例代码

代码语言:txt
复制
INSERT INTO customers (customer_id, customer_name) VALUES (1, 'John Doe');
INSERT INTO orders (order_id, order_date, customer_id) VALUES (1, '2023-10-01', 1);

问题3:唯一约束冲突

原因:尝试插入重复的唯一值。

解决方法

  • 确保插入的数据在唯一约束列上是唯一的。
  • 使用UNIQUE索引来优化查询性能。

示例代码

代码语言:txt
复制
CREATE TABLE products (
    product_id INT PRIMARY KEY,
    product_code VARCHAR(20) UNIQUE,
    product_name VARCHAR(100) NOT NULL
);

通过以上介绍和示例代码,希望你能更好地理解MySQL数据库的单表约束及其应用场景和解决方法。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL单表&约束&事务

DQL操作单表 排序 # 通过 ORDER BY 子句,可以将查询出的结果进行排序(排序只是显示效果,不会影响真实数据) SELECT 字段名 FROM 表名 [WHERE 字段 = 值] ORDER...违反约束的不正确数据,将无法插入到表中 常见的约束 约束名 约束关键字 主键 primary key 唯一 unique 非空 not null 外键 foreign key 主键约束 特点:不可重复...,对自增没有影响,使用truncate 是将整个表删除掉,然后创建一个新的表 自增的主键,重新从 1开始 非空约束 非空约束的特点: 某一列不予许为空 # 非空约束 CREATE TABLE emp2...ename VARCHAR(20) UNIQUE, sex CHAR(1) ); 主键约束与唯一约束的区别: 主键约束 唯一且不能够为空 唯一约束,唯一 但是可以为空 一个表中只能有一个主键 , 但是可以有多个唯一约束...MySQL 事务隔离级别 一个数据库可能拥有多个访问客户端,这些客户端都可以并发方式访问数据库. 数据库的相同数据可能被多个事务同时访问,如果不采取隔离措施,就会导致各种问题, 破坏数据的完整性。

1.2K30

MYSQL数据库-表的约束

零、前言 本章主要讲解学习MYSQl数据库中的表的约束 表的约束 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性...在关系数据库中,索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单 索引的作用相当于图书的目录...这样可以使对应于表的SQL语句执行得更快,可快速访问数据库表中的特定信息 7、唯一键 一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题...,不创建外键约束,就正常建立学生表,以及班级表,该有的字段我们都有,在实际使用的时候,可能会出现有没有可能插入的学生信息中有具体的班级,但是该班级却没有在班级表中,这很明显是有问题的 因为此时两张表在业务上是有相关性的...解决方案就是通过外键完成的。建立外键的本质其实就是把相关性交给mysql去审核了,提前告诉mysql表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入

7.5K30
  • MySQL数据库:表的约束

    表的约束,实质上就是用数据类型去约束字段,但是数据类型的约束手法很单一,比如,我们在设置身份证号这个字段,数据类型唯一起的约束是它属于char类型或者varchar类型,不能是浮点型也不能是日期时间类型...自增长的特点: ⭐任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)。 ⭐自增长字段必须是整数。 ⭐一张表最多只能有一个自增长。...2 | +------------------+ 1 row in set (0.00 sec) 唯一键 一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题...,提前告诉mysql表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入。...综合案例: 有一个商店的数据,记录客户及购物情况,有以下三个表组成: 商品goods(商品编号goods_id,商品名goods_name, 单价unitprice, 商品类别category, 供应商

    28230

    MySQL数据库表约束详解

    1.表的约束的概念 表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。约束本质是通过技术手段,倒逼程序员,插入正确的数据。...站在正常的业务逻辑中: 如果班级没有名字,你不知道你在哪个班级 如果教室名字可以为空,就不知道在哪上课 所以我们在设计数据库表的时候,一定要在表中进行限制,满足上面条件的数据就不能插入到表中。...自增长的特点: 任何一个字段要做自增长,前提是本身是一个索引(key一栏有值) 自增长字段必须是整数 一张表最多只能有一个自增长 案例: mysql> create table tt21( -> id...所以我们需要在从表上建立外键约束将主表的班级的和从表的班级进行一个外键的约束,这样保证我们每次插入和删除数据都是正确的!...两张表在业务上是有相关性的,但是在业务上没有建立约束关系,那么就可能出现问题。 解决方案就是通过外键完成的。

    7600

    【MySql】表的约束

    表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。约束的本质是通过技术收到逼迫程序员插入正确的数据,反过来,站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。...站在正常的业务逻辑中: 如果班级没有名字,你不知道你在哪个班级 如果教室名字可以为空,就不知道在哪上课 所以我们在设计数据库表的时候,一定要在表中进行限制,满足上面条件的数据就不能插入到表中。...OK, 1 row affected (0.00 sec) 唯一键unique 一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题...因为此时两张表在业务上是有相关性的,但是在业务上没有建立约束关系,那么就可能出现问题。 解决方案就是通过外键完成的。...建立外键的本质其实就是把相关性交给mysql去审核了,提前告诉mysql表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入。

    21530

    MySQL表的约束

    所谓约束,就是避免犯一些低级错误,比如类似于语法错误,编译器的编译失败实际上也算是一种约束。 表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。...约束的本质: 通过技术手段倒逼程序员插入正确的数据。反过来站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。 约束的最终目标: 保证数据的完整性和可预期性。 为什么数据库这么严格?...数据库作为维护用户数据的最后一道防线,必须要保证数据库的数据是满足预期的,因此数据库的约束必须严格。为了更好的约束,就需要更多的约束条件,这也是这一节的内容。...二.表的非空约束 1.NULL与’ '比较 在MySQL数据类型已经说过,这二者是不同的,NULL代表什么都没有,而' '代表一个空串。 在select语句中,NULL不会参与到相应的计算操作中。...2.空属性null 在这个约束中,有两个选择: null(默认的) not null(不为空) 数据库默认字段基本都是字段允许为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运算。

    22650

    【MYSQL】表的约束

    我们看到有zerofill关键字的在有效数据前会用0来填充,直至设定的宽度。...自增长的特点: 任何一个字段要做自增长,前提是本身是一个索引(key一栏有值) 自增长字段必须是整数 一张表最多只能有一个自增长 关键字:auto_increament 案例: create table...索引: 在关系数据库中,索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结 构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。...这样可以使对应于表的SQL语句执行得更快,可快速访问数据库表中的特定信息 七、唯一键 一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。 具体指的是在公司的业务上不能重复,我们设计表的时候,需要这个约束,那么就可以将员工工号设计成为唯一键。

    25340

    MySQL:表的约束

    表的约束和约束的目标 表的约束:表中一定要有各种约束,通过约束,让我们未来插入数据库中的数据是符合预期的。约束本质是通过技术手段,倒逼程序员,插入正确的数据。...反过来,站在MySQL角度,凡是插入进来的数据,都是符合数据约束的! 约束的最终目标:保证数据的完整性和可预期性。 二....站在正常的业务逻辑中: 如果班级没有名字,你不知道你在哪个班级。 如果教室名字为空,就不知道在哪上课。 所以我们在设计数据库表的时候,一定要在表中进行限制,满足上面条件的数据就不能插入到表中。...像这样主键是有唯一性的,这是没问题的。 如果我插入的元素电话列,发生了冲突,但是主键又只能有一个,所以这里就需要唯一键来约束,保证电话的唯一性。...外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。

    6710

    【MySQL】表的约束

    表的约束 表的约束:表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。约束本质是通过技术手段,倒逼用户,插入正确的数据。...反过来,在 mysql 角度,凡是插入进来的数据,都是符合数据约束的!约束的最终目的就是保证数据的完整性和可预期性。因此我们需要更多的约束条件!...七、唯一键 唯一键:unique;一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键;唯一键就可以解决表中有多个字段需要唯一性约束的问题。...所以以上两张表现在只有关联关系,却没有约束关系,是有问题的!外键就很好地解决了这个问题,外键就是为这两张表建立外键约束。 那么我们要为哪个表添加外键约束呢?...建立外键的本质其实就是把相关性交给 mysql 去审核了,提前告诉 mysql 表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql 不允许你插入。

    15510

    数据库技术:MySQL 基础和 SQL 入门,单表、约束和事务

    MySQL 中管理着很多数据库,在实际开发环境中 一个数据库一般对应了一个的应用,数据库当中保存着多张表,每一张表对应着不同的业务,表中保存着对应业务的数据。...Show Database -- 切换数据库 从db1 切换到 db1_1 USE db1_1; -- 查看当前正在使用的数据库 SELECT DATABASE(); -- 查看Mysql中有哪些数据库...查看当前正在使用的数据库 show databases; -- 查看 MySQL 中都有哪些数据库 show create database 数据库名; -- 查看一个数据库的定义信息 Alter Database...违反约束的不正确数据,将无法插入到表中。 Primary Key -- 主键约束 主键约束是不可重复的、唯一的、非空的,用来表示数据库中的每一条记录。...主键约束与唯一约束的区别:1. 主键约束是唯一的且不能够为空,唯一约束是唯一的但可以为空;2. 一个表中只能有一个主键,但是可以有多个唯一约束。

    1.5K20

    MySQL数据库——表的约束(非空约束、唯一约束、主键约束、外键约束)

    目录 1 表的约束 约束,是对表中的数据进行限定,保证数据的正确性、有效性和完整性,约束分为以下几类: 主键约束:primary key 非空约束:not null 唯一约束:unique 外键约束:foreign...UNIQUE ); 注意:MySQL中唯一约束限定的列的值可以有多个null 2)删除唯一约束: -- alter table stu modify number varchar(20); 不同于非空约束的删除方法...主键约束:primary key 1)注意: 若某一列添加了该约束,则代表了非空,且唯一; 一张表只能有一个字段为主键; 主键就是表中记录的唯一标识; 2)创建表时添加主键约束 CREATE TABLE...外键,就是从表中与主表主键对应的那一列,如:员工表中的dep_id,其中,主表是一方,用来约束别人的表,从表可以是多方,被别人约束的表。 注意:外键可以为NULL,但是不能是不存在的外键值。 ?...employee (NAME, age, dep_id) VALUES ('小王', 18, 2); SELECT * FROM employee; SELECT * FROM department; 因为有外键的约束

    14.6K21

    MySQL之表的约束

    一 介绍 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性 主要分为: PRIMARY KEY (PK) 标识该字段为该表的主键,可以唯一的标识记录 FOREIGN...,被约束的字段必须同时被key约束 #不指定id,则自动增长 create table student( id int primary key auto_increment, name varchar(...:工号  姓名  部门 公司有3个部门,但是有1个亿的员工,那意味着部门这个字段需要重复存储,部门名字越长,越浪费 解决方法: 我们完全可以定义一个部门表 然后让员工信息表关联该表,如何关联,即foreign...id外键到丈夫表的id #多对多 三张表:出版社,作者信息,书 多对多:一个作者可以写多本书,一本书也可以有多个作者,双向的一对多,即多对多    关联方式:foreign key+一张新的表 ===...,一个客户有可能变成一个学校,即一对一的关系 关联方式:foreign key+unique #一定是student来foreign key表customer,这样就保证了: #1 学生一定是一个客户

    4.9K60

    【MySQL】008-表的约束

    : ""与NULL是不同的两个概念; 说明链接:https://blog.csdn.net/u014743697/article/details/54136092 2、删除name的非空约束,本质上就是更改表的字段...: -- 删除name的非空约束 ALTER TABLE stu MODIFY NAME VARCHAR(20); 3、创建表完成之后添加约束,本质上也是更改表的字段: -- 创建表之后,添加name的非空约束...NAME VARCHAR(20); 3、创建表之后,添加唯一约束,本质是修改对应字段 -- 创建表之后,添加name的非空约束 ALTER TABLE stu MODIFY NAME VARCHAR(20...-- 主键约束 NAME VARCHAR(20) ); 3、删除主键约束和创建表之后添加主键约束与非空约束和唯一约束一样 五、主键约束——自动增长 1、概念 如果某一列是数值类型的,使用auto_increment...) ); 注意:添加语句时主键的内容填入NULL即可,会根据上一个主键的值进行自动增加 3、删除自动增长和创建表后自动增长,同非空约束和唯一约束; 六、外键约束 1、描述 个人理解:加入一个部门的员工表

    6910

    MySQL表的完整性约束

    概览   为了防止不符合规范的数据进入数据库,在用户对数据进行插入、修改、删除等操作时,DBMS自动按照一定的约束条件对数据进行监测,使不符合规范的数据不能进入数据库,以确保数据库中存储的数据正确、有效...约束条件与数据类型的宽度一样,都是可选参数,主要分为以下几种: # NOT NULL :非空约束,指定某列不能为空; # UNIQUE : 唯一约束,指定某列或者几列组合不能重复 # PRIMARY...AUTO_INCREMENT 约束字段为自动增长,被约束的字段必须同时被key约束 ? ?...返回顶部 FOREIKEY 多表 : 假设我们要描述所有公司的员工,需要描述的属性有这些 : 工号 姓名 部门 公司有3个部门,但是有1个亿的员工,那意味着部门这个字段需要重复存储,部门名字越长,越浪费...Restrict方式 同no action, 都是立即检查外键约束 . Set default方式 父表有变更时,子表将外键列设置成一个默认的值 但Innodb不能识别

    3.5K20

    MySQL 学习(二)常见的数据库有哪些?

    那我们再来看下其他几款数据库管理软件。 排名第一的 Oracle,它是一个商业的关系型数据库管理软件,公司的名字也叫做 Oracle。Oracle 功能丰富,但是收费也比较高。...排名第四的是 PostgreSQL,稳定性极强,最符合 SQL 标准,和 MySQL 一样,开放源码,现在也是非常流行的数据库。...关系型数据库的英文名是 RDBMS,R 代表 Relationship,从之前的 数据库 排名中,我们可以看出来,关系数据库绝对是数据库管理系统的主流,使用最多的 Oracle、MySQL、SQL Server...关系型数据库模型就是把 复杂的数据结构归结为 简单的二元关系,类似图中的 excel 表格。 关系型数据库以 行和 列的形式来存储数据,我们查询出来的数据其实就是一个列表,包含了列名和行的数据。...关系型数据库有很多好处,比如支持非常复杂的关联查询,就是说可以用 SQL 语句来支持查一张表或多张有关联关系的表。 还支持事务,就是说 关系型数据库的可用性和稳定性得到了保证。

    2.5K40
    领券