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

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

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

以下是每种约束的示例:

  1. PRIMARY KEY 约束:
CREATE TABLE students (
    student_id INT PRIMARY KEY,
    name VARCHAR(50),
    age INT
);
  1. FOREIGN KEY 约束:
CREATE TABLE orders (
    order_id INT PRIMARY KEY,
    product_id INT,
    quantity INT,
    FOREIGN KEY (product_id) REFERENCES products (product_id)
);
  1. UNIQUE 约束:
CREATE TABLE users (
    username VARCHAR(50) UNIQUE,
    email VARCHAR(100) UNIQUE,
    age INT
);
  1. NOT NULL 约束:
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 约束:
CREATE TABLE messages (
    message_id INT PRIMARY KEY,
    sender_id INT,
    receiver_id INT,
    message_text VARCHAR(255) DEFAULT 'No message'
);
  1. CHECK 约束:
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 约束:
CREATE TABLE invoices (
    invoice_id INT PRIMARY KEY AUTO_INCREMENT,
    customer_id INT,
    total_amount DECIMAL(10, 2)
);

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

相关推荐

  1. MySQL数据库字段约束学习笔记

    2024-06-05 21:10:06       10 阅读
  2. MySQL约束

    2024-06-05 21:10:06       32 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-05 21:10:06       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-05 21:10:06       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-05 21:10:06       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-05 21:10:06       20 阅读

热门阅读

  1. GB-T 43698-2024 网络安全技术 软件供应链安全要求

    2024-06-05 21:10:06       8 阅读
  2. MFC CList<CRect, CRect&> m_listRect;的用法

    2024-06-05 21:10:06       10 阅读
  3. 旅游卡系统开发搭建

    2024-06-05 21:10:06       7 阅读
  4. 【vivado】如何用vivado查看高扇出路径

    2024-06-05 21:10:06       9 阅读
  5. IT技术培训班:实用还是虚幻?

    2024-06-05 21:10:06       8 阅读
  6. Flutter 中的 SliverAnimatedList 小部件:全面指南

    2024-06-05 21:10:06       7 阅读
  7. Lua 元表(Metatable)深入解析

    2024-06-05 21:10:06       9 阅读
  8. webpack包含哪些核心模块,分别是做什么的?

    2024-06-05 21:10:06       9 阅读
  9. Python爬虫要掌握哪些东西

    2024-06-05 21:10:06       6 阅读
  10. Qt程序发布工具windeployqt.exe所带来的坑

    2024-06-05 21:10:06       10 阅读
  11. C++中的List

    2024-06-05 21:10:06       8 阅读
  12. x264 参考帧管理原理:i_frame_num 变量

    2024-06-05 21:10:06       10 阅读