首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

sequelize( 4.3.0版)中与自定义主键的关联

在sequelize(4.3.0版)中,可以使用自定义主键来建立关联关系。自定义主键是指在数据库表中,使用非默认的字段作为主键。

在sequelize中,可以通过定义模型的primaryKey属性来指定自定义主键。例如,假设我们有两个模型:User和Post,它们之间的关联是通过User模型的自定义主键id与Post模型的外键userId建立的。

首先,我们需要在定义User模型时指定自定义主键id:

代码语言:javascript
复制
const { Sequelize, DataTypes } = require('sequelize');
const sequelize = new Sequelize('database', 'username', 'password', {
  host: 'localhost',
  dialect: 'mysql'
});

const User = sequelize.define('User', {
  id: {
    type: DataTypes.INTEGER,
    primaryKey: true,
    autoIncrement: true
  },
  name: {
    type: DataTypes.STRING,
    allowNull: false
  }
});

// ...

module.exports = User;

然后,在定义Post模型时,使用belongsTo方法建立与User模型的关联:

代码语言:javascript
复制
const { Sequelize, DataTypes } = require('sequelize');
const sequelize = new Sequelize('database', 'username', 'password', {
  host: 'localhost',
  dialect: 'mysql'
});

const Post = sequelize.define('Post', {
  title: {
    type: DataTypes.STRING,
    allowNull: false
  },
  content: {
    type: DataTypes.TEXT,
    allowNull: false
  }
});

Post.belongsTo(User, { foreignKey: 'userId' });

// ...

module.exports = Post;

在上述代码中,belongsTo方法用于建立Post模型与User模型的关联关系。通过foreignKey选项,我们指定了外键字段名为userId。

这样,我们就建立了sequelize中自定义主键的关联关系。在实际使用中,可以通过调用模型的关联方法来进行查询和操作相关数据。

推荐的腾讯云相关产品:腾讯云数据库MySQL、腾讯云云服务器CVM、腾讯云云函数SCF。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Django自定义带有前后缀递增主键

最近项目中遇到一个需求,在Djangomodel主键要带有前缀递增类型主键,比如:exp-1, exp-2…,类似.这样,而且在所有的model主键里面递增数据要唯一,不能有重复。...也就是如果有A和B两个model,那么当exp-1在A中使用过之后就不允许在B再使用。在网上找了一圈没有找到特别好实现方法,自己写了一个,在这里做个记录。...我采用方法其实也很简单: 创建一个单独model,里面只有一个models.AutoField类型字段,可以确保主键递增数字是全局唯一 在实际业务model定义一个models.CharFiled...类型主键 修改save方法,为业务模型主键加上前缀 下面是示例代码,可以参考 from django.db import models class AutoIncrementFields(models.Model

8710
  • Sequelize 系列教程之多对多模型关系

    它具有强大事务支持,关联关系、读取和复制等功能。在阅读本文前,如果你对 Sequelize 还不了解,建议先阅读 Sequelize 快速入门 这篇文章。...数据模型表关系一般有三种:一对一、一对多、多对多。Sequelize 为开发者提供了清晰易用接口来定义关系、进行表之间操作。本文我们将介绍在 Sequelize 如何定义多对多表关系。...Project 模型(作为参数传递模型)是 target 。 belongsToMany 多对多关联用于将源多个目标相连接。 此外,目标也可以连接到多个源。...删除任何先前定义主键属性 - 表将由两个表组合唯一标识,并且没有其他主键列。...):设置当前 note 记录, tag3、tag4 之间关联信息,对应 SQL 语句如下: INSERT INTO `taggings` (`type`,`createdAt`,`updatedAt

    12.7K30

    【Node】sequelize 使用对象方式操作数据库

    (sequelize, DataTypes) { return sequelize.define( "person", // 给模型自定义个名字,通常是表名驼峰写法 {...('NOW') }, }, }, }); 3.2 查询 - 关联表 简单描述下 通常不同类型数据存放不同表,但是不同表数据之间是有关联,比如 用户表和 评论表,所以需要表表之间建立联系...,所以 sequelize 会推断外键在 IdCard 为 personId,如果没有就会报错 [找不到 idCard.personId 这个字段] 自定义外键,在 IdCard 外键为 user_id...通过主键或者 唯一索引 比如表已经存在 id 为 1 数据,此时你再插入 id 为1 数据,那么就只会进行更新,不会再插入 下面介绍几个添加场景 1、限定插入字段 2、限定更新字段 3、关联表创建...2、数据库自带外键约束 只要在数据库表定义了两表关联外键,那么当删除父表数据时,子表关联数据也会被自动删除。

    8.4K20

    【融职培训】Web前端学习 第8章 egg基础教程4 sequelize

    一、ORM框架概述 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象关系数据库存在互不匹配现象技术。...简单说,ORM是通过使用描述对象和数据库之间映射元数据,将程序对象自动持久化到关系数据库。那么,到底如何实现持久化呢?...一旦出现业务需求变更,就必须修改持久化层接口 持久化层同时域模型关系数据库模型绑定,不管域模型还是关系数据库模型发生变化,毒药修改持久化曾相关程序代码,增加了软件维护难度。...;//数据库字段类型,一对多 const Clazz = app.model.define('clazz', { //sequelize会自动创建主键 name: STRING...14 as: 'clazz'//将关联数据显示到该字段上 15 }) 16 } 17 18 return Students; 19 } 四、

    1.3K20

    sequelize常用api

    sequelize-cli基本流程 sequelize规定 模型名称是单数、表名称是复数 总置文件就是用来给数据库mock添加数据文件 生成文章表模型 sequelize model:generate...findByPk ===== 通过主键id查找 let article = await Article.findByPk(99) 上面表示通过Article模型查询主键id为99这个数据,和查询单条数据区别不大...({where:{name:'小九'}}) 和上面的一样,查询这个用户是否存在,存在再进行删除,防止出现删除用户在数据库并不存在这种操作,多人操作情况下可能会出现这种情况,所以可以使用这个方法。...查询条件 上面我们已经知道了基本查询语法,但是实际业务查询可能更为麻烦,我们看看在sequelize还提供了哪些参数吧: something.findOne({ order: [ /...提供了 order and group 参数,来 ORDER BY 和 GROUP BY 一起使用.

    7.9K30

    Web前端学习 第8章 egg基础教程4 sequelize

    一、ORM框架概述 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象关系数据库存在互不匹配现象技术。...简单说,ORM是通过使用描述对象和数据库之间映射元数据,将程序对象自动持久化到关系数据库。那么,到底如何实现持久化呢?...一旦出现业务需求变更,就必须修改持久化层接口 持久化层同时域模型关系数据库模型绑定,不管域模型还是关系数据库模型发生变化,毒药修改持久化曾相关程序代码,增加了软件维护难度。...;//数据库字段类型,一对多 const Clazz = app.model.define('clazz', { //sequelize会自动创建主键 name: STRING...14 as: 'clazz'//将关联数据显示到该字段上 15 }) 16 } 17 18 return Students; 19 } 四、

    1.3K10

    Sequelize 系列教程之一对一模型关系

    它具有强大事务支持,关联关系、读取和复制等功能。在阅读本文前,如果你对 Sequelize 还不了解,建议先阅读 Sequelize 快速入门 这篇文章。...数据模型表关系一般有三种:一对一、一对多、多对多。Sequelize 为开发者提供了清晰易用接口来定义关系、进行表之间操作。本文我们将介绍在 Sequelize 如何定义一对一表关系。...,将从目标模型名称和目标主键名称生成 belongsTo 关系外键。...HasOne 在 target 模型插入关联键,而 BelongsTo 将关联键插入到 source 模型。...// 在target模型插入关联键 // Account实例对象将拥有getUser、setUser、createUser方法 Account.belongsTo

    8.4K10

    C++自定义结构体或类作为关联容器

    概述 STL像set和map这样容器是通过红黑树来实现,插入到容器对象是顺序存放,采用这样方式是非常便于查找,查找效率能够达到O(log n)。...所以如果有查找数据需求,可以采用set或者map。 但是我们自定义结构体或者类,无法对其比较大小,在放入到容器时候,就无法正常编译通过,这是set/map容器规范决定。...要将自定义结构体或者类存入到set/map容器,就需要定义一个排序规则,使其可以比较大小。...最简单办法就是在结构体或者类中加入一个重载小于号成员函数,这样在存数据进入set/map时,就可以根据其规则排序。 2....实例 在这里就写了一个简单例子,将自定义一个二维点存入set/map,并查找其中存入数据: #include #include #include #include

    2.1K20

    Sequelize入门

    它具有强大事务支持, 关联关系, 预读和延迟加载,读取复制等功能. Sequelize 遵从 语义版本控制. 支持 Node v10 及更高版本以便使用 ES6 功能....Getting Started - Sequelize入门 在本教程,你将进行学习 Sequelize 简单设置....术语约定 请注意,在上面的示例,Sequelize 是指库本身,而 sequelize 是指 Sequelize 实例,它表示一个数据库连接. 这是官方推荐约定,在整个文档中都将遵循....新数据库现有数据库 如果你是从头开始一个项目,且你数据库尚不存在,那么一开始就可以使用 Sequelize,以便自动创建数据库每个表....记录日志 默认情况下,Sequelize 将记录控制台执行每个SQL查询. 可以使用 options.logging 参数来自定义每次 Sequelize 记录某些内容时将执行函数.

    1.4K20

    如何将QGIS属性表Excel表格关联

    本期作者:尼克 易知微3D引擎技术负责人QGIS是一款开源且具备完整地理信息系统桌面GIS软件,主要功能包括数据浏览、地图制图、数据管理编辑、空间数据处理空间分析、地图服务等框架。...QGISExcel之间数据并不完全兼容,而UE开发过程中大部分前期数据都储存在Eecel里。...为了将Excel数据写入QGIS属性表实现数据可视化,我们内部总结了一个最快捷方法⬇️step 1.添加ID列在QGIS属性表添加一个id列,并写入编号step 2.创建Excel创建一个Excel...添加Excel表格数据在QGIS文件浏览器,选择excel表格,添加图层到工程查看excel属性表数据step 4....在工具箱搜索「重构字段」将id2类型修改为文本(字符串),运行step 5.连接数据属性在工具箱搜索「按字段值连接属性」step 6.对应输入图层输入图层为原图层;输入图层2为Excel表图层;选择好对应字段

    17610

    如何优雅地操作数据库?ORM了解一下

    什么是ORM img 对象关系映射(Object Relational Mapping,简称ORM),是一种程序技术,实现面向对象编程语言中内存对象关系型数据库业务实体之间关系映射。...它具有强大事务支持, 关联关系, 预读和延迟加载,读取复制等功能。 Sequelize 遵从 语义版本控制。支持 Node v10 及更高版本以便使用 ES6 功能。...连接数据库 设置使用sequlize插件,并配置要连接数据库 定义Model 通过面向对象Class 和 关系型数据库表建立连接 @Column 表示数据库一列 @PrimaryKey 表示主键...缺点 无可避免,自动化意味着映射和关联管理,代价是牺牲性能。现在各种ORM框架都在尝试使用各种方法来减轻性能上损失,如懒加载技术、缓存技术等。...持久化层缺乏弹性,一旦出现业务需求变更,就必须修改持久化层接口 持久化层同时域模型关系数据库模型绑定,不管域模型还是关系数据库模型发生变化,都要修改持久化层相关程序代码,增加了软件维护难度。

    1.8K20

    基于 Egg.js 框架 Node.js 服务构建之用户管理设计

    类似于 J2EE DAO 设计模式,将程序数据对象自动地转化为关系型数据库对应表和列,数据对象间引用也可以通过这个工具转化为表。...id 设计, 需要通过字段 primaryKey:true 指定为主键。...(组)操作数据集; count:计算数据库中元素出现次数; max:获取特定表格特定属性最大值; min:获取特定表格特定属性最小值; sum:特定属性值求和; create:创建数据库 Model...团队开发时,有人喜欢自己加 timestamp,有人又喜欢自增主键,并且自定义表名。一个大型 Web App 通常都有几十个映射表,一个映射表就是一个 Model。...JWT 组成 一个 JWT 实际上就是一个字符串,它由三部分组成,头部、载荷签名。

    9.3K40

    万字长文之 Serverless 实战详细指南

    时序图 如上时序图所示, 本次实现简易博客系统, 只有博客列表页和博客内容页, 不涉及评论, 登录, 侧重于 Serverless 落地相关内容, 如云函数本身怎么编写, 怎么在本地开发, 怎么跟自定义域名关联...腾讯云 MySQL 数据库设计 因为是一个简易博客系统, 不涉及登录和评论, 在满足数据库设计第三范式基础上, 我们只需要设计一张表即可, 即博客表本身: 字段名 字段类型 id 主键 title..., 这里我们就不再说明啦~ 后边会有 Sequelize, 还有怎么连接, 操作数据库介绍~ 云函数自定义域名 API 网关映射 域名解析 前面说到, 云函数创建完配置好 API 网关触发器后, 就可以在外网访问了...; module.exports = { Sequelize, sequelize, Model, } blog 是数据库名称, root 是登录账户, 密码存放在环境变量...期间涉及了如何创建云函数, 介绍了本地 VSCode 云函数插件, 云函数自定义域名 API 网关映射, 云数据库创建连接, 云函数代码组织方式等.

    1.6K30

    Loadrunner 运行场景-场景全局变量关联结果参数

    结果:每个用户全局变量取值日志都一样,先输出 "value_for_int_var" = "1",然后输出"value_for_int_var" = "2" 结论:针对全局变量,针对场景每个用户...Paramter ListVuserID Action2 模拟把服务器返回结果当作下一步输入来使用 Action2() { int vuserID; int result; lr_start_transaction...vuserID, vuser_id); if(vuserID == vuser_id){ return 1; }else{ return 0; } } 把上述脚本加载到场景,...结论:场景,每个并发用户负责自己数据结果。...关联参数 基于A实验结果,关联参数取值也是一样,所以,并发场景下,也可以通过关联函数web_reg_save_param获取服务器返回结果,并在下一个步骤中使用

    82110

    JPA规范:一对多、一对一、多对多双向关联级联操作以及JPA联合主键

    通常在企业开发,开发Dao层有两种做法:  (1)先建表,后再根据表来编写配置文件和实体bean。使用这种方案开发人员受到了传统数据库建模影响。 ...一、一对多双向关联级联操作: 以订单类和订单商品类为例: 多一方为关系维护端,关系维护端负责外键记录更新,关系被维护端是没有权利更新外键记录。...具体配置步骤可以参看这篇博客:https://blog.csdn.net/a745233700/article/details/81415550 二、一对一双向关联级联操作: 以身份证类和人为例: 1...Person("小张"); person.setIdcard(new IDcard("448xxx1990xxxx1234")); em.persist(person); } 三、多对多双向关联级联操作...2、AirLinkPK联合主键类: /*联合主键三个要求: 1.必须定义无参构造函数 2.必须实现序列化接口Serializable 3.必须重写hashCode()和equals()方法 */ @Embeddable

    3K30
    领券