Vriesianman 2020-08-25 15:10 采纳率: 0%
浏览 193

关于mysql中uuid作为主键的使用。

我想在mysql中使用uuid这个函数,现在遇到一个问题就是我想让uuid作为主键,但是似乎uuid的使用需要用触发器,比如这样

CREATE TRIGGER `orders_id` BEFORE INSERT ON `orders` FOR EACH ROW 
BEGIN
IF new.id is null then 
set new.id=UUID();
end if;
end;

但是这个触发器的前提是插入的id为空,可是如果作为主键这时候插入的数据必须是非空的,就形成了一个矛盾,这该怎么解决,如何让uuid完美的作为mysql的主键,希望大佬指点一二。

  • 写回答

2条回答 默认 最新

  • jingluan666 2020-08-25 18:34
    关注

    如果字段不允许空,插入时肯定不能显示插入NULL,但是可以省略插入的列

    insert into tb(id,name) 写成 insert into tb(name)

    评论

报告相同问题?

悬赏问题

  • ¥15 编辑cmake lists 明明写了project项目名,但是还是报错怎么回事
  • ¥15 关于#计算机视觉#的问题:求一份高质量桥梁多病害数据集
  • ¥15 特定网页无法访问,已排除网页问题
  • ¥50 如何将脑的图像投影到颅骨上
  • ¥15 提问一个关于vscode相关的环境配置问题,就是输入中文但是显示不出来,代码在idea可以显示中文,但在vscode不行,不知道怎么配置环境
  • ¥15 netcore使用PuppeteerSharp截图
  • ¥20 这张图页头,页脚具体代码该怎么写?
  • ¥15 关于#sql#的问题,请各位专家解答!
  • ¥20 WPF MVVM模式 handycontrol 框架, hc:SearchBar 控件 Text="{Binding NavMenusKeyWords}" 绑定取不到值
  • ¥15 需要手写数字信号处理Dsp三个简单题 不用太复杂