详解MySQL中default的使用

2023-03-01 10:29:34 作者:admin

本文整理自网络,侵删。

NULL 和 NOT NULL 修饰符、DEFAULT 修饰符,AUTO_INCREMENT 修饰符。

NULL 和 NOT NULL 修饰符

可以在每个字段后面都加上这 NULL 或 NOT NULL 修饰符来指定该字段是否可以为空(NULL),

还是说必须填上数据 (NOT NULL)。MySQL 默认情况下指定字段为 NULL 修饰符,如果一个字段指定为NOT NULL,

MySQL 则不允许向该字段插入空值(这里面说的空值都为 NULL),因为这是 “规定”。

/* 创建好友表,其中id ,name ,pass都不能为空 */ create table friends ( id int(3) not null, name varchar(8) not null, pass varchar(20) not null ); /* 错误提示,id列不能为空 #1048 - Column 'id' cannot be null */ insert INTO friends VALUES ( NULL , 'simaopig', 'simaopig' ); 

但是在自增列和 TIMESTAMP 字段中,这个规则并不适用。

向这些字段中插入 NULL 值将会导致插入下一个自动增加的值或者当前的时间戳。

DEFAULT 修饰符

可以使用 DEFAULT 修饰符为字段设定一个默认值。

当插入记录时,您老人家忘记传该字段的值时,MySQL 会自动为您设置上该字段的默认值。

/* 创建im表,将name字段设置为默认值'QQ' */ create table im ( id int(3) not null, name varchar(25) not null default 'QQ' ); /* 插入数据,不传name字段的值,MySQL会为其设置默认值的 您运行的 SQL 语句已经成功运行了。 */ insert INTO im( id, name ) VALUES ( 2, 'MSN' ) ; insert INTO im( id ) VALUES ( 3 ) ; select * FROM im LIMIT 0 , 30; /* id name 2 MSN 3 QQ */ 

如果一个字段中没有指定 DEFAULT 修饰符,MySQL 会依据这个字段是 NULL 还是 NOT NULL 自动设置默认值。

如果指定字段可以为 NULL,则 MySQL 为其设置默认值为 NULL。

阅读剩余部分

相关阅读 >>

关于mysql中的时间进位问题的讲解

phpmyadmin #1045错误无法登录mysql服务器怎么办?

mysql学习之临时表相关总结

mysql8.0.23 msi安装超详细教程

mysql之权限以及设计数据库案例讲解

mysql5.7中的json基本操作指南

mysql mid()函数的用法详解(代码示例)

mysql使用技巧之行类视图子查询

最全的mysql调试与优化技巧

mysql中的四大运算符种类实例汇总(20多项)

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



在线咨询 拨打电话