首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在已标准化的vuex-orm数据库中插入数据

在已标准化的vuex-orm数据库中插入数据
EN

Stack Overflow用户
提问于 2020-05-05 16:27:09
回答 1查看 471关注 0票数 2

假设我收到的数据已经正常化,或者至少是关系。如何将这些数据插入vuex-orm数据库?

示例JSON数据:

代码语言:javascript
复制
{
  "carmodel": [
    {
      "id": 1,
      "title": "M3",
      "manufacturer_id": 1
    },
    {
      "id": 2,
      "title": "a-class"
      "manufacturer_id": 2
    }
  ],
  "manufacturer": [
    {
      "id": 1,
      "title": "BMW"
    },
    {
      "id": 2,
      "title": "Mercedes"
    }
  ]
}

制造商模型和are模型插入如下:

代码语言:javascript
复制
Manufacturer.insert({ data: response.data.manufacturer })
CarModel.insert({ data: response.data.carmodel })

此示例模型将无法工作:

代码语言:javascript
复制
import { Model } from '@vuex-orm/core'
import Manufacturer from '@/models/Manufacturer'

export default class CarModel extends Model {
  static entity = 'carModels'

  static fields () {
    return {
      id: this.attr(null),
      title: this.string(''),
      manufacturer: this.hasOne(Manufacturer, 'manufacturer_id')
    }
  }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-05-05 17:16:52

好吧,我想我明白了。与this.hasOne不同,我必须使用belongsTo并使用来自同一个模型的manufacturer_id:

代码语言:javascript
复制
import { Model } from '@vuex-orm/core'
import Manufacturer from '@/models/Manufacturer'

export default class CarModel extends Model {
  static entity = 'carModels'

  static fields () {
    return {
      id: this.attr(null),
      title: this.string(''),
      manufacturer_id: this.attr(null),
      manufacturer: this.belongsTo(Manufacturer, 'manufacturer_id')
    }
  }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61618081

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档