Sequelize操作Mysql时使用默认值

当使用 Sequelize 创建模型时,开发人员可以在属性定义中使用 defaultValue 来设置默认值。本文介绍使用默认值的一些常见的场景:

  1. 字符串类型 (Sequelize.STRING):

    javascript 复制代码
    const User = sequelize.define('user', {
      username: {
        type: Sequelize.STRING,
        defaultValue: 'DefaultUsername',
      },
    });
  2. 整数类型 (Sequelize.INTEGER):

    javascript 复制代码
    const Post = sequelize.define('post', {
      likes: {
        type: Sequelize.INTEGER,
        defaultValue: 0,
      },
    });
  3. 布尔类型 (Sequelize.BOOLEAN):

    javascript 复制代码
    const Task = sequelize.define('task', {
      completed: {
        type: Sequelize.BOOLEAN,
        defaultValue: false,
      },
    });
  4. 日期类型 (Sequelize.DATE):

    javascript 复制代码
    const Event = sequelize.define('event', {
      eventDate: {
        type: Sequelize.DATE,
        defaultValue: Sequelize.NOW, // 当前日期和时间
      },
    });
  5. UUID 类型 (Sequelize.UUID):

    javascript 复制代码
    const Product = sequelize.define('product', {
      productId: {
        type: Sequelize.UUID,
        defaultValue: Sequelize.UUIDV4, // 生成 UUIDv4
      },
    });
  6. 使用函数作为默认值:

    javascript 复制代码
    const Task = sequelize.define('task', {
      description: {
        type: Sequelize.STRING,
        defaultValue: () => 'Default Description',
      },
    });
  7. 特殊默认值 - 当前日期和时间 (Sequelize.NOW):

    javascript 复制代码
    const LogEntry = sequelize.define('logEntry', {
      logDate: {
        type: Sequelize.DATE,
        defaultValue: Sequelize.NOW,
      },
    });

实例

下面举一个史记中的例子说明,如何使用默认值将每条记录的主键(id)设置成随机的字符串。具体的做法为:使用 Sequelize 的 defaultValue 选项结合一个生成随机字符串的函数。

js 复制代码
const Sequelize = require('sequelize');
const { v4: uuidv4 } = require('uuid'); // 使用 uuid 库生成随机字符串

const User = sequelize.define('user', {
  id: {
    type: Sequelize.STRING,
    primaryKey: true,
    defaultValue: () => uuidv4(), // 使用 uuidv4() 生成随机字符串
  },
  username: {
    type: Sequelize.STRING,
    allowNull: false,
  },
  // 其他属性...
});

// 示例:创建新用户
User.create({
  username: 'exampleUser',
}).then((newUser) => {
  console.log('New user created with id:', newUser.id);
});
相关推荐
天天扭码11 小时前
前端如何实现RAG?一文带你速通,使用RAG实现长期记忆
前端·node.js·ai编程
Knight_AL11 小时前
MySQL 中 UPDATE 语句的执行过程全解析
数据库·mysql
梁萌12 小时前
ShardingSphere分库分表实战
数据库·mysql·实战·shardingsphere·分库分表
川石课堂软件测试13 小时前
Mysql中触发器使用详详详详详解~
数据库·redis·功能测试·mysql·oracle·单元测试·自动化
程序员游老板13 小时前
基于SpringBoot3_vue3_MybatisPlus_Mysql_Maven的社区养老系统/养老院管理系统
java·spring boot·mysql·毕业设计·软件工程·信息与通信·毕设
soft200152515 小时前
从一次增删改操作开始:彻底理解 MySQL Buffer Pool 的地位与作用
数据库·mysql
晨曦54321015 小时前
MySQL与Python数学函数大比拼
python·mysql
q_191328469515 小时前
基于SpringBoot2+Vue2的行业知识答题考试系统
java·vue.js·spring boot·mysql·毕业设计·计算机毕业设计·演示文稿
hxmmm15 小时前
自定义封装 vue多页项目新增项目脚手架
前端·javascript·node.js
濮水大叔16 小时前
VonaJS是如何做到文件级别精确HMR(热更新)的?
typescript·node.js·nestjs