SQL的五大约束作用、语法、应用场景及举例

SQL的五大约束包括主键约束(PRIMARY KEY)、唯一性约束(UNIQUE)、外键约束(FOREIGN KEY)、非空约束(NOT NULL)和默认约束(DEFAULT)

sql约束的作用:主要是保证数据的完整性、准确性和一致性 ,从而确保 数据库中存储的数据质量

温馨提示:以下举例为mysql版本,若您是oracle或其他数据库,语法会有差异!!!

  1. 主键约束(PRIMARY KEY) :确保某列必须要有唯一的标识符。
    应用场景 :用于唯一标识数据库表中的每条记录。
    注意点 :一个表中只能有一个主键,主键列的值必须是唯一的,不能为空。
    举例

    CREATE TABLE Employees (
    EmployeeID int NOT NULL,
    FirstName varchar(50),
    LastName varchar(50),
    BirthDate date,
    PRIMARY KEY (EmployeeID)
    );

在上述示例中,EmployeeID被定义为主键,确保每个员工都有一个唯一的标识符。

当表被创建后,可以使用ALTER TABLE语句来添加或删除约束

复制代码
--添加
ALTER TABLE 表名   ADD PRIMARY KEY (列名);
--例子:将"user_info"表的"UserID"列设置为主键
ALTER TABLE user_info ADD PRIMARY KEY (UserID);
--删除
ALTER TABLE 表名  DROP  PRIMARY KEY ;
--例子:删除用户表的主键
ALTER TABLE user_info DROP PRIMARY KEY ;
  1. 唯一性约束(UNIQUE) :唯一性约束确保在非主键列中不输入重复的值。
    应用场景 :用于防止在列中输入重复的值。
    注意点 :唯一性约束允许空值,但当和参与唯一性约束的任何值一起使用时,每列只允许一个空值。
    举例

    复制代码
    CREATE TABLE Users (  
        UserID int NOT NULL,  
        Username varchar(50) NOT NULL,  
        Email varchar(100),  
        UNIQUE (Username),  
        UNIQUE (Email)  
    );

    在上述示例中,UsernameEmail字段都被定义为唯一约束,确保用户名和电子邮件地址都是唯一的。
    当表被创建后,可以使用ALTER TABLE语句来添加或删除约束

    --添加唯一约束
    ALTER TABLE 表名 ADD UNIQUE (列名);
    -- 例子
    ALTER TABLE user_info ADD UNIQUE (USERID);
    -- 删除唯一约束
    ALTER TABLE 表名 DROP KEY 字段名;
    -- 例子
    ALTER TABLE user_info DROP KEY USERID;

  2. 外键约束(FOREIGN KEY) :外键约束用于强制参照完整性,提供单个字段或者多个字段的参照完整性。
    应用场景 :用于保证数据库表之间的关系,确保数据表中的数据符合某种引用完整性。
    注意点:外键列的值必须在被参照表的相应列中有对应的数据。

    复制代码
    CREATE TABLE Orders (  
        OrderID int NOT NULL,  
        OrderNumber int NOT NULL,  
        CustomerID int,  
        PRIMARY KEY (OrderID),  
        FOREIGN KEY (CustomerID) REFERENCES Customers(CustomerID)  
    );

    Orders表中的CustomerID字段是一个外键,它引用另一个表Customers中的CustomerID字段,确保订单与客户的关联关系。

    当表被创建后,可以使用ALTER TABLE语句来添加或删除约束

    --添加外键
    ALTER TABLE 表名 ADD FOREIGN KEY 约束名(列名) REFERENCES 另一个表名 (列名);
    -- 例子
    ALTER TABLE user_role ADD FOREIGN KEY user_role_userid (userid) REFERENCES user_info (userid);
    -- 删除外键
    ALTER TABLE 表名 DROP FOREIGN KEY 约束名;
    -- 例子
    ALTER TABLE user_role DROP FOREIGN key user_role_userid ;

  3. 非空约束(NOT NULL) :设置非空约束,该字段不能为空。
    应用场景 :用于确保某列必须有值,不能为NULL。
    注意点:非空约束是一种强制性的约束,它要求列中的值必须被指定,不能为NULL。

    CREATE TABLE ContactDetails (
    ContactID int NOT NULL,
    Name varchar(100) NOT NULL,
    PhoneNumber varchar(20)
    );

在上述示例中,Name字段被定义为非空约束,确保联系人的姓名不能为空。

当表被创建后,可以使用ALTER TABLE语句来添加或删除约束

复制代码
--添加非空约束
ALTER TABLE 表名 MODIFY 列名 字段类型 NOT NULL;
-- 例子
ALTER TABLE user_info MODIFY userID varchar(64)  NOT NULL;
-- 删除非空约束
ALTER TABLE 表名 MODIFY 列名 字段类型 NULL;
-- 例子
ALTER TABLE user_info MODIFY userID varchar(64) NULL;
  1. 默认约束(DEFAULT) :该数据的默认值。
    应用场景 :为没有提供输入值的字段或列提供默认值。
    注意点:默认值必须满足列的数据类型的要求,如果未指定值则会自动使用默认值。

    复制代码
    CREATE TABLE Products (  
        ProductID int NOT NULL,  
        ProductName varchar(100),  
        Price decimal(10, 2),  
        DefaultStock int DEFAULT 0
    );

    在上述示例中,DefaultStock字段被定义为默认约束,其默认值为0。当插入新产品时,如果没有指定库存数量,则会默认给0。

    当表被创建后,可以使用ALTER TABLE语句来添加或删除约束

    --添加DEFAULT约束
    ALTER TABLE 表名 ALTER 字段名 SET DEFAULT 默认值;
    -- 例子
    ALTER TABLE user_info ALTER CITY SET DEFAULT '北京';
    -- 删除DEFAULT约束
    ALTER TABLE 表名 ALTER 字段名 DROP DEFAULT;
    -- 例子
    ALTER TABLE user_info ALTER CITY DROP DEFAULT;

相关推荐
Channing Lewis31 分钟前
sql server如何创建表导入excel的数据
数据库·oracle·excel
秃头摸鱼侠31 分钟前
MySQL安装与配置
数据库·mysql·adb
UGOTNOSHOT36 分钟前
每日八股文6.3
数据库·sql
行云流水行云流水1 小时前
数据库、数据仓库、数据中台、数据湖相关概念
数据库·数据仓库
John Song1 小时前
Redis 集群批量删除key报错 CROSSSLOT Keys in request don‘t hash to the same slot
数据库·redis·哈希算法
IvanCodes1 小时前
七、Sqoop Job:简化与自动化数据迁移任务及免密执行
大数据·数据库·hadoop·sqoop
tonexuan1 小时前
MySQL 8.0 绿色版安装和配置过程
数据库·mysql
JohnYan2 小时前
工作笔记- 记一次MySQL数据移植表空间错误排除
数据库·后端·mysql
我最厉害。,。2 小时前
Windows权限提升篇&数据库篇&MYSQL&MSSQL&ORACLE&自动化项目
数据库·mysql·sqlserver
远方16092 小时前
20-Oracle 23 ai free Database Sharding-特性验证
数据库·人工智能·oracle