mysql实现将列默认值设置为uuid

 更新时间:2025年11月10日 09:05:23   作者:nayi_224  
在MySQL 8.1.0中建表时,主键和普通列都可以设置默认值,需要注意的是,使用UUID()函数时必须加上括号,否则会报错,修改时同样需要加括号,目前无法使用自定义函数作为默认值,MySQL也不支持,可以使用内置函数如LENGTH、CONCAT等,但若可能,应尽量避免使用触发器来设置默认值

使用mysql版本为8.1.0

建表时设置

create table test(
  uuid varchar(100) NOT NULL default (uuid()) ,
  aaaa varchar(100) not null default (uuid()) ,
  primary key(uuid) 
);

可以看到主键和普通列都可以设置,但是要注意uuid()要加上括号,否则会报错

修改时设置

ALTER TABLE test MODIFY uuid VARCHAR(36) DEFAULT (uuid());
ALTER TABLE test MODIFY aaaa VARCHAR(36) DEFAULT (uuid());

同样注意要添加括号

使用自定义函数

目前没有使用默认值的方式设置成功过,mysql好像不支持使用自定义函数作为默认值

CREATE FUNCTION custom_function_name()
RETURNS int
DETERMINISTIC
BEGIN
    RETURN 1;
END;
ALTER TABLE test MODIFY aaaa VARCHAR(36) DEFAULT (custom_function_name());


会报错 3770 - Default value expression of column 'aaaa' contains a disallowed function: custom_function_name.

而使用其他内置函数,如length、concat等是可以的

这时应该只能使用触发器了,需要注意的是,在设置默认值时,只要能不使用触发器,就一定不要使用

CREATE FUNCTION custom_function_name()
RETURNS int
DETERMINISTIC
BEGIN
    RETURN 1;
END;

create trigger tri_test_uuid
before insert on test
for each ROW
BEGIN
    SET new.aaaa=custom_function_name();
END
;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 解决mysql导入还原时乱码的问题

    解决mysql导入还原时乱码的问题

    sql文件,直接记事本方式打开,中文显示正常,还原导入后,发现中文是乱码
    2012-12-12
  • MySQL中怎么匹配年月

    MySQL中怎么匹配年月

    一般数据库中给到的时间都是年-月-日形式的,那怎么匹配年-月/的形式呢,下面通过实例代码介绍怎么在数据库中查询到关于2021年8月的数据,对mysql匹配年月相关知识,感兴趣的朋友跟随小编一起看看吧
    2024-04-04
  • Mysql Explain 详细介绍

    Mysql Explain 详细介绍

    这篇文章主要介绍了Mysql Explain 详细介绍的相关资料,这里对Mysql Explain 的语法,属性,以及如何使用,做了全面介绍,需要的朋友可以参考下
    2016-11-11
  • 详解MySQL数据库insert和update语句

    详解MySQL数据库insert和update语句

    用于操作数据库的SQL一般分为两种,一种是查询语句,也就是我们所说的SELECT语句,另外一种就是更新语句,也叫做数据操作语句。接下来通过本文给大家介绍MySQL数据库insert和update语句,需要的朋友一起学习吧
    2016-04-04
  • mysql myisam 优化设置设置

    mysql myisam 优化设置设置

    mysql myisam 优化设置设置,需要的朋友可以参考下。
    2010-03-03
  • MySQL 中的 LIMIT 语句及基本用法

    MySQL 中的 LIMIT 语句及基本用法

    LIMIT 语句用于限制查询返回的行数,常用于分页查询或取部分数据,提高查询效率,本文给大家介绍MySQL 中的 LIMIT 语句,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2025-06-06
  • MySQL系统库之information_schema的实现

    MySQL系统库之information_schema的实现

    information_schema用于存储数据库元数据,本文主要介绍了MySQL系统库之information_schema的实现,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • 使用mysqldump对MySQL的数据进行备份的操作教程

    使用mysqldump对MySQL的数据进行备份的操作教程

    这篇文章主要介绍了使用mysqldump对MySQL的数据进行备份的操作教程,示例环境基于CentOS操作系统,需要的朋友可以参考下
    2015-12-12
  • MySQL数据库的多种连接方式以及实用工具

    MySQL数据库的多种连接方式以及实用工具

    mysql连接操作是客户端进程与mysql数据库实例进程进行通信,下面这篇文章主要给大家介绍了关于MySQL数据库的多种连接方式以及实用工具的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • MYSQL常用字符串函数和时间函数示例详解

    MYSQL常用字符串函数和时间函数示例详解

    字符串函数是最常用的的一种函数,在一个具体应用中通常会综合几个甚至几类函数来实现相应的应用,这篇文章主要介绍了MYSQL常用字符串函数和时间函数的相关资料,需要的朋友可以参考下
    2025-07-07

最新评论