0

0

mysql如何设置默认值_mysql字段默认值配置说明

P粉602998670

P粉602998670

发布时间:2026-02-12 15:26:50

|

702人浏览过

|

来源于php中文网

原创

mysql建表时用default设默认值,支持常量和current_timestamp等函数,不支持子查询或表达式;not null字段必须显式定义default,否则插入无值时报错;alter table修改默认值需用modify或drop default。

mysql如何设置默认值_mysql字段默认值配置说明

MySQL 字段默认值怎么设(CREATE TABLE 时)

建表时用 DEFAULT 关键字直接指定,默认值可以是常量、函数(如 CURRENT_TIMESTAMP),但不能是子查询或表达式(如 1+1NOW()+INTERVAL 1 DAY)。

常见写法示例:

CREATE TABLE users (
  id INT PRIMARY KEY AUTO_INCREMENT,
  name VARCHAR(50) NOT NULL,
  status TINYINT DEFAULT 1,
  created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
  updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);
  • DEFAULT 1 对数值型字段安全;DEFAULT 'active' 对字符串需加引号
  • TIMESTAMPDATETIME 支持 CURRENT_TIMESTAMP,但 DATETIME 在 MySQL 5.6.5+ 才支持带毫秒和 ON UPDATE
  • 如果字段定义了 NOT NULL 又没设 DEFAULT,插入时没给值会报错:Field 'xxx' doesn't have a default value

ALTER TABLE 添加或修改 DEFAULT 值

已有表加默认值,必须用 ALTER TABLE ... ALTER COLUMN ... SET DEFAULT(MySQL 8.0.13+)或旧语法 MODIFY/CHANGE 配合重定义字段。

推荐方式(兼容性好):

帮小忙
帮小忙

腾讯QQ浏览器在线工具箱平台

下载
ALTER TABLE users MODIFY status TINYINT DEFAULT 0;
  • MODIFY 时要重复写出完整字段定义(类型、约束等),否则可能意外丢掉 NOT NULL 或其他属性
  • 想删掉默认值:用 DROP DEFAULT,不是设成 DEFAULT NULL(后者仍是默认值,且对 NOT NULL 字段无效)
  • 执行后不会影响已有数据,只作用于后续 INSERT 未显式赋值的行

NULL 作为默认值是否合法?

是合法的,但行为容易误解。如果字段允许 NULL 且没写 DEFAULT,MySQL 实际隐式按 DEFAULT NULL 处理;但如果显式写 DEFAULT NULL,语义更清晰。

  • name VARCHAR(50) DEFAULT NULL ✅ 明确允许空值且默认为空
  • name VARCHAR(50) NOT NULL DEFAULT NULL ❌ 冲突,直接报错
  • name VARCHAR(50) → 等价于 DEFAULT NULL(前提是没 NOT NULL
  • 注意:JSON 类型字段不能设 DEFAULT '',必须用 DEFAULT (JSON_OBJECT())DEFAULT NULL

默认值不生效的几个典型原因

写了 DEFAULT 却发现插入时还是报错或值不对,大概率是这几个点卡住了:

  • SQL mode 含 STRICT_TRANS_TABLESSTRICT_ALL_TABLES:此时若字段 NOT NULL 且无默认值,哪怕插入 NULL 也会拒绝
  • 客户端驱动(如 JDBC)自动把空字符串转成 NULL,而字段又 NOT NULL,导致绕过默认值逻辑
  • 使用了 INSERT INTO t VALUES () 这种全字段省略写法,但表里有自增主键以外的 NOT NULL 字段且无默认值,就会失败
  • 触发器(BEFORE INSERT)里主动给字段赋了值,覆盖了默认值

真正麻烦的是混合了严格模式、ORM 自动生成 SQL、以及历史遗留的无默认值 NOT NULL 字段——这种组合下,加默认值只是第一步,还得检查所有写入路径是否真会“用上”它。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

901

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

333

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

372

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1572

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

368

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1128

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

583

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

433

2024.04.29

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

1

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 832人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号