Bookshelf.js - 如何保存多对多关系?

2024-01-09

我在以“多对多”关系保存数据时遇到问题。

这是我的模型:

 var CoursePeople = bookshelf.Model.extend({
     tableName: 'course_people'
 });

 var Course = bookshelf.Model.extend({
     tableName: 'course',
     users: function(){
         return this.belongsToMany(User);
     }
 });

 var City = bookshelf.Model.extend({
     tableName: 'city',
     users: function(){
         return this.hasMany(User);
     }
 });

 var User = bookshelf.Model.extend({
   tableName: 'people',
   city: function(){
     return this.belongsTo(City);
   },
   courses: function(){
     return this.belongsToMany(Course);
   }
 });

挑战是,如何将数组中获得的 ID 插入数据库中的联结表(名为“course_people”)?

到目前为止,这是我的代码:

 app.post('/users/', function(req, res) {
         console.log(req.body);
     var courses_ids = req.body.courses_ids; //array of ids
     delete req.body.courses_ids;
     new User(req.body).save().then(function(user){
         console.log(user.id);
         //How to store the ids in the junction table?

     }).catch(function(error){
         console.log(error);
     });
 });

再次感谢您的时间和建议!


您想要在这里做的是将 id 附加到您的关系中,如下所示:

app.post('/users/', function(req, 
  console.log(req.body);
  var courses_ids = req.body.courses_ids; //array of ids
  delete req.body.courses_ids;
  new User(req.body).save()
    .then(function(user){
     // this is important
      return user.courses().attach(courses_ids);
    }).catch(function(error){
       console.log(error);
    });
});

官方文档中也有说明:https://bookshelfjs.org/api.html#Collection-instance-attach https://bookshelfjs.org/api.html#Collection-instance-attach

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Bookshelf.js - 如何保存多对多关系? 的相关文章

随机推荐

  • 通过变量访问Go函数[重复]

    这个问题在这里已经有答案了 我刚刚开始学习 Go 有些事情引起了我的注意 功能如下 delete map Answer for maps append slice 0 for slices len slice cap slice again
  • constexpr 计算负位移位时未定义的行为?

    考虑以下代码片段 int main constexpr int x 1 if x gt 0 constexpr int y 1 lt
  • 如何在 AWS Route 53 中将流量从非 www 域名重定向到 www.example.com

    我在 AWS Route 53 中拥有一个域名 www derbyware com 我有一个 Web 应用程序运行在 http node147934 env 7029269 phx enscaled us http node147934 e
  • 如何运行独立的 Eclipse MAT?

    我使用 jmap 生成了 hprof sudo jdk bin jmap F dump file app hprof 5003 现在 我在 eclipse 中解析 hprof 时遇到 OOM Java Heap Space 错误 我想我需要
  • GLEW 链接问题找不到 __imp_glGetIntegerv

    注意 是的 我已经指定了 GLEW STATIC 因此 在尝试设置glew以在新项目中使用之前 我已经经历过这个牛仔竞技表演 但现在我在项目中使用glew 2 0 它产生了链接错误 我刚刚在 Linux 实例中生成了源代码并像这样使用它们
  • Celery + Redis - .get() 平稳运行约 70 小时后无限期挂起

    几天内一切都运行良好 但后来我无限期地挂在 get 上 发生无限期挂起所需的时间各不相同 但都在运行 24 到 72 小时之间 我怀疑这与Redis代理有关 的输出CLIENT LIST in redis cli显示大量连接且空闲数非常高
  • fullcalendar js 中未显示的事件

    请任何人帮我找出代码中出了什么问题 我使用 fullcalendar js 来处理日历事件 我想在日历中显示事件 下面是我的代码 document ready function window resize function calendar
  • 使用采样数据时CRC32函数如何工作?

    我想问你关于Python中以下短函数的解释 from zlib import crc32 def test set check identifier test ratio return crc32 np int64 identifier 0
  • Getline错误MFC vs2012(msvcp110.dll)

    我在使用 vs2012 中的 std getline 函数与 MFC 应用程序时遇到问题 同样的代码在vs2010中运行 这就是为什么我确信这不是代码本身的问题 void AddImage OnClickedIdbAiRegistratio
  • 具有自动完成功能的自定义交互式 Shell

    我的任务是创建一个嵌入到 python 中的交互式 shell 这样 当从命令行调用时 它将被放入该 shell 中 谁能给我推荐一个可以做到这一点的图书馆 我需要能够创建自定义单词 操作 以便当用户键入这些单词时 我的程序可以执行我创建的
  • 在 .js 文件中执行 PHP 代码

    我试图在 js 文件中执行一些 PHP 代码 但显然不知道如何正确执行 基本上 代码是向我的页面添加一些 HTML 标签 我将其用于滑出式联系表单 然而 联系表单本身是在 Wordpress 中通过短代码完成的 因此 我试图让短代码在使表单
  • 指定内容的构建操作 - Nuget

    告诉 Nuget 包将所有 css 文件添加为嵌入式资源 即构建操作是嵌入式资源 的最简单方法是什么 我试图通过工具文件夹中的 install ps1 来完成此操作 但仍然无法到达任何地方 注意 我正在从目录结构 tools content
  • switch case 编程练习

    enum SQLErrorCode OK 0 PARTIAL OK 1 SOMEWHAT OK 2 NOT OK 3 Code 1 int error getErrorCode if error SQLErrorCode PARTIAL O
  • 我可以通过 ssh 连接到 Windows,启动命令并让它在我注销时运行吗?

    现在 Windows 10 包含了 openSSH 服务器 是否有某种方法可以启动程序并让它在我注销时运行 在 Linux 上 有 screen 和 tmux 但是 Windows 上呢 Notes 能够重新附加到进程会很好 但这不是必需的
  • 当 list-marker 是伪元素时,list-style-position 不起作用。为什么?

    我想创建彩色列表标记 ul 我做到了 但现在在所有列表中list style position属性不起作用 这是代码 ul FirmStyle list style type none ul FirmStyle li before colo
  • asp.net正则表达式验证器客户端脚本错误

    我有以下正则表达式验证器来检测输入字符串是否包含 HTML 脚本标记 如果是则导致验证错误
  • Nodejs从哪里开始?

    我已经安装了nodejs并运行了几个简单的示例 例如在端口上打开服务器并侦听该端口 但是 我仍然无法将nodejs与web开发联系起来 所以为了学习和实现nodejs 我正在考虑使用rails和nodejs制作井字游戏 这可能吗 我正在设想
  • jQuery 可拖动自定义对齐网格

    我在项目中使用 jQuery UI Draggable 我有一个复选框可以切换可拖动对象上的网格 10x10 网格 选项 但是 当网格重新打开时 网格关闭时移动的对象不会与网格关闭时未移动的对象对齐 简而言之 这些对象位于不对齐的单独网格上
  • 自定义错误页面 .Net Core Web 应用程序未显示 500 错误

    我在生产中创建了一个自定义错误页面 它将要求用户更正 HTTP 状态代码页面 而不是显示丑陋的开发人员错误页面 我现在的代码如下 启动 cs public void Configure IApplicationBuilder app IHo
  • Bookshelf.js - 如何保存多对多关系?

    我在以 多对多 关系保存数据时遇到问题 这是我的模型 var CoursePeople bookshelf Model extend tableName course people var Course bookshelf Model ex