MySQL之数据库字段约束学习笔记(三)

MySQL 中的字段约束用于限制字段的取值范围,确保数据的一致性和完整性。常见的字段约束包括:

  1. PRIMARY KEY:定义主键约束,唯一标识表中的每一行数据。
  2. FOREIGN KEY:定义外键约束,确保两个表之间的关联完整性。
  3. UNIQUE:确保字段值的唯一性,但允许 NULL 值。
  4. NOT NULL:确保字段值不为空。
  5. DEFAULT:为字段指定默认值。
  6. CHECK:定义自定义的数据完整性约束,例如范围限制或正则表达式。
  7. AUTO_INCREMENT:自动递增字段的值,通常用于主键。

以下是每种约束的示例:

  1. PRIMARY KEY 约束:
sql 复制代码
CREATE TABLE students (
    student_id INT PRIMARY KEY,
    name VARCHAR(50),
    age INT
);
  1. FOREIGN KEY 约束:
sql 复制代码
CREATE TABLE orders (
    order_id INT PRIMARY KEY,
    product_id INT,
    quantity INT,
    FOREIGN KEY (product_id) REFERENCES products (product_id)
);
  1. UNIQUE 约束:
sql 复制代码
CREATE TABLE users (
    username VARCHAR(50) UNIQUE,
    email VARCHAR(100) UNIQUE,
    age INT
);
  1. NOT NULL 约束:
sql 复制代码
CREATE TABLE employees (
    employee_id INT PRIMARY KEY,
    first_name VARCHAR(50) NOT NULL,
    last_name VARCHAR(50) NOT NULL,
    department_id INT
);
  1. DEFAULT 约束:
sql 复制代码
CREATE TABLE messages (
    message_id INT PRIMARY KEY,
    sender_id INT,
    receiver_id INT,
    message_text VARCHAR(255) DEFAULT 'No message'
);
  1. CHECK 约束:
sql 复制代码
CREATE TABLE products (
    product_id INT PRIMARY KEY,
    name VARCHAR(50),
    price DECIMAL(10, 2),
    quantity INT,
    CHECK (price > 0),
    CHECK (quantity >= 0)
);
  1. AUTO_INCREMENT 约束:
sql 复制代码
CREATE TABLE invoices (
    invoice_id INT PRIMARY KEY AUTO_INCREMENT,
    customer_id INT,
    total_amount DECIMAL(10, 2)
);

通过使用这些字段约束,可以确保数据库中的数据完整性,并避免不符合预期的数据插入或修改操作。

相关推荐
九章-几秒前
国企国产化替代标杆实践:金仓数据库赋能贵州磷化EMS系统自主可控升级
数据库·mysql·安全
利刃大大3 分钟前
【Mybatis】Mybatis入门 && 基础操作 && XML配置文件开发 && 多表查询 && 注入问题 && 数据库连接池
xml·数据库·mybatis
Mr.朱鹏6 分钟前
大模型入门学习路径(Java开发者版)下
java·python·学习·微服务·langchain·大模型·llm
老华带你飞13 分钟前
志愿者服务管理|基于springboot 志愿者服务管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring
William_cl1 小时前
【CSDN 精品专栏】ASP.NET Razor 变量输出 @变量名:从入门到避坑,新手也能写对!
java·数据库·asp.net
困死了11111 小时前
PostgreSQL笔记
数据库·笔记·postgresql
尤物程序猿1 小时前
spring的监听器的几种使用方式
java·数据库·spring
老华带你飞1 小时前
学生请假管理|基于springboot 学生请假管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端·spring
YJlio1 小时前
ProcessExplorer_17.09_x64-Chs 新版本升级:我看到的区别与优势(含升级思路与注意点)
人工智能·笔记·学习
-木槿昔年-2 小时前
【米尔-安路MYD-YM90X创意秀】飞龙派学习和PS串口实践
学习·fpga开发