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)
);

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

相关推荐
拥抱AGI4 分钟前
Qwen3.5开源矩阵震撼发布!从0.8B到397B,不同规模模型性能、显存、速度深度对比与选型指南来了!
人工智能·学习·程序员·开源·大模型·大模型训练·qwen3.5
程序员老邢10 分钟前
【产品底稿 04】商助慧 V1.1 里程碑:爬虫入库 + MySQL + Milvus 全链路打通
java·爬虫·mysql·ai·springboot·milvus
TDengine (老段)14 分钟前
中原油田引入时序数据库 TDengine:写入性能提升、存储成本下降 85%
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
IT邦德18 分钟前
Oracle 26ai搭建ADG Far Sync日志备库
数据库·oracle
Crazy CodeCrafter26 分钟前
现在做服装,实体和电商怎么选?
大数据·数据库·人工智能·微信·开源软件·零售
sp_fyf_202426 分钟前
【大语言模型】从失败中学习:在微调大型语言模型作为智能体时整合负例
人工智能·深度学习·学习·机器学习·语言模型·自然语言处理
一江寒逸35 分钟前
零基础从入门到精通MongoDB(下篇):进阶精通篇——吃透高级查询、事务、索引优化与集群架构,成为MongoDB实战高手
数据库·mongodb·架构
sa1002739 分钟前
一键获取淘宝天猫商品评论:API 接口实战与多语言实现教程
数据库·oracle
秋雨梧桐叶落莳43 分钟前
【iOS】 AutoLayout初步学习
学习·macos·ios·objective-c·cocoa·xcode
huanmieyaoseng10031 小时前
Linux安装达梦数据库DM8
linux·运维·数据库