首页 小组 文章 相册 留言本 用户 搜索 我的社区 在线学堂 商城 购物车 支付钱包

[打卡]谷加伟——约束2

2024-05-21 15:09:59
0
202

# not NULL (非空约束)只能用列级约束,不能表级约束

CREATE DATABASE shoolbd;

USE schoolbd;

# 在CREATE TABLE 时添加约束

CREATE TABLE test1(
id INT NOT NULL,

last_name VARCHAR(15) NOT NULL,

email VARCHAR(20),

salary INT
);

DESC test1;

INSERT INTO test1(id,last_name,email,salary)
VALUES
(1,'Tom','tom@126',5000);

SELECT*FROM test1;

UPDATE test1
SET email = NULL
WHERE id = 1;

UPDATE test1
SET salary = null
WHERE id = 1;

desc test1;

# 在ALTER TABLE 时添加约束

# 如果本身unll值,再改为not null 的话不能添加

# 一般情况下不用

ALTER TABLE test1
MODIFY email VARCHAR(25) NOT NULL;

DESC test1;

# 在ALTER TABLE 时删除约束

ALTER TABLE test1
MODIFY last_name VARCHAR(15) NULL;

DESC test1;

# UNIQUE 唯一性约束

# 在 CREATE TABLE 在创建表示添加约束
可以列级约束也可以表级约束

CREATE TABLE test2(

id INT UNIQUE, #列级约束

last_name VARCHAR(15),

email VARCHAR (25),

salary INT,

# 表级约束

CONSTRAINT uk_test2_email
UNIQUE (email)

)

DESC test2;

# 在ALTER TABLE 时添加约束

# 方式一

ALTER TABLE test2
ADD CONSTRAINT uk_test2_sal UNIQUE (salary);

DESC test2;

-------------------------------

SELECT * FROM test2;

INSERT INTO test2(id,last_name,email,salary)
VALUES
(1,'Tom','tom@126',5000);


# 方式二

DESC test2;

ALTER TABLE test2
MODIFY last_name VARCHAR(15) UNIQUE;

DESC test2;

# 查询所有字段约束

SELECT* FROM information_schema.TABLE_CONSTRAINTS
WHERE table_name = 'test2';

评论
意见反馈