MySQL非空约束(not|MySQL非空约束(not null)案例讲解
目录
- 在创建表时设置非空约束
- 在修改表时添加非空约束
- 删除非空约束
比如,在用户信息表中,如果不添加用户名,那么这条用户信息就是无效的,这时就可以为用户名字段设置非空约束。
在创建表时设置非空约束 创建表时可以使用 NOT NULL 关键字设置非空约束,具体的语法格式如下:
<字段名> <数据类型> NOT NULL;例 1
创建数据表 tb_dept4,指定部门名称不能为空,SQL 语句和运行结果如下所示。
mysql> CREATE TABLE tb_dept4-> (-> id INT(11) PRIMARY KEY,-> name VARCHAR(22) NOT NULL,-> location VARCHAR(50)-> ); Query OK, 0 rows affected (0.37 sec)mysql> DESC tb_dept3; +----------+-------------+------+-----+---------+-------+| Field| Type| Null | Key | Default | Extra |+----------+-------------+------+-----+---------+-------+| id| int(11)| NO| PRI | NULL||| name| varchar(22) | NO|| NULL||| location | varchar(50) | YES|| NULL||+----------+-------------+------+-----+---------+-------+3 rows in set (0.06 sec)
在修改表时添加非空约束 如果在创建表时忘记了为字段设置非空约束,也可以通过修改表进行非空约束的添加。
修改表时设置非空约束的语法格式如下:
ALTER TABLE <数据表名>例 2
CHANGE COLUMN <字段名>
<字段名> <数据类型> NOT NULL;
修改数据表 tb_dept4,指定部门位置不能为空,SQL 语句和运行结果如下所示。
mysql> ALTER TABLE tb_dept4-> CHANGE COLUMN location-> location VARCHAR(50) NOT NULL; Query OK, 0 rows affected (0.15 sec)Records: 0Duplicates: 0Warnings: 0mysql> DESC tb_dept4; +----------+-------------+------+-----+----------+-------+| Field| Type| Null | Key | Default| Extra |+----------+-------------+------+-----+----------+-------+| id| int(11)| NO| PRI | NULL||| name| varchar(22) | NO|| NULL||| location | varchar(50) | NO|| NULL||+----------+-------------+------+-----+----------+-------+3 rows in set (0.00 sec)
删除非空约束 修改表时删除非空约束的语法规则如下:
ALTER TABLE <数据表名>例 3
CHANGE COLUMN <字段名> <字段名> <数据类型> NULL;
修改数据表 tb_dept4,将部门位置的非空约束删除,SQL 语句和运行结果如下所示。
mysql> ALTER TABLE tb_dept4-> CHANGE COLUMN location-> location VARCHAR(50) NULL; Query OK, 0 rows affected (0.15 sec)Records: 0Duplicates: 0Warnings: 0mysql> DESC tb_dept4; +----------+-------------+------+-----+----------+-------+| Field| Type| Null | Key | Default| Extra |+----------+-------------+------+-----+----------+-------+| id| int(11)| NO| PRI | NULL||| name| varchar(22) | NO|| NULL||| location | varchar(50) | YES|| NULL||+----------+-------------+------+-----+----------+-------+3 rows in set (0.00 sec)
到此这篇关于MySQL非空约束(not null)案例讲解的文章就介绍到这了,更多相关MySQL非空约束(not null)内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 真正的爱
- py连接mysql
- 2019-01-18Mysql中主机名的问题
- MySql数据库备份与恢复
- mysql|InnoDB数据页结构
- mysql中视图事务索引与权限管理
- MYSQL主从同步的实现
- MySQL数据库的基本操作
- javaweb|基于Servlet+jsp+mysql开发javaWeb学生成绩管理系统
- Python3|Python3 MySQL 数据库连接