Loopbackjs Strongloop loopback:如何在启动脚本中的模型实例上添加相关模型实例

Loopbackjs Strongloop loopback:如何在启动脚本中的模型实例上添加相关模型实例,loopbackjs,strongloop,database-relations,Loopbackjs,Strongloop,Database Relations,我正在为一个学校平台制作一个API。 我想在我还在开发的时候,在启动脚本中迁移数据库并为其设定种子 我可以创建学校实例、组实例和个人实例,但我不知道如何在个人实例和组实例(多对多)之间添加关系 这是我的Person.json文件: { "name": "Person", "base": "User", "strict": true, "idInjection": true, "properties": { "name": { "type": "string

我正在为一个学校平台制作一个API。 我想在我还在开发的时候,在启动脚本中迁移数据库并为其设定种子

我可以创建学校实例、组实例和个人实例,但我不知道如何在个人实例和组实例(多对多)之间添加关系

这是我的Person.json文件:

{
  "name": "Person",
  "base": "User",
  "strict": true,
  "idInjection": true,
  "properties": {
    "name": {
      "type": "string",
      "required": true
    },
    "firstName": {
      "type": "string",
      "required": true
    }
  },
  "validations": [],
  "relations": {
    "groups": {
      "type": "hasAndBelongsToMany",
      "model": "Group"
    },
    "school": {
      "type": "belongsTo",
      "model": "School"
    }
  },
  "acls": [],
  "methods": []
}
这是我的group.json文件

{
  "name": "Group",
  "base": "PersistedModel",
  "strict": true,
  "idInjection": true,
  "properties": {
    "name": {
      "type": "string",
      "required": true
    }
  },
  "validations": [],
  "relations": {
    "people": {
      "type": "hasAndBelongsToMany",
      "model": "Person"
    },
    "school": {
      "type": "belongsTo",
      "model": "School"
    }
  },
  "acls": [],
  "methods": []
}
这是我的启动脚本:

var async = require('async');

module.exports = function(app) {
    var mysqlDs = app.dataSources.mysqlDs;
    var boysNames = ["Lucas", "Liam", "Arthur", "Vince", "Noah", "Finn", "Mathis", "Louis", "Adam", "Jules", "Lars", "Seppe", "Stan", "Alexander", "Leon", "Kobe", "Victor", "Matteo", "Milan", "Mats", "Vic", "Wout", "Daan", "Senne", "Ferre", "Tuur", "Nathan", "Elias", "Warre", "Jack", "Felix", "Cas", "Thomas", "Lowie", "Robbe", "Lewis", "Rayan", "Nand", "Sem", "Maxim", "Emiel", "Jasper", "Oscar", "Mauro", "Sam", "Mohamed", "Luca", "Bent", "Ruben", "Simon", "Imran", "Jayden", "Lou", "Viktor", "Bas", "Lenn", "Rune", "Lukas", "Eden", "Emile"];
    var girlsNames = ["Emma", "Louise", "Elise", "Ella", "Marie", "Noor", "Lena", "Julie", "Lotte", "Olivia", "Anna", "Elena", "Mila", "Lore", "Fien", "Nina", "Lina", "Nora", "Laura", "Juliette", "Charlotte", "Lisa", "Amber", "Amélie", "Fleur", "Renée", "Lily", "Sara", "Camille", "Hanne", "Luna", "Liv", "Roos", "Helena", "Sarah", "Sofia", "Janne", "Noa", "Jade", "Nore", "Fenna", "Axelle", "Kato", "Alice", "Aya", "Jana", "Lize", "Paulien", "Amelie", "Lucie", "Lara", "Zoë", "Mona", "Manon", "Leonie", "Ines", "Oona", "Laure", "Mira", "Febe"];
    var names = ["Jong","Jansen","Vries","Visser","Jans","Bakker","Dijk","Vos","Smit","Berg","Boer","Groot","Janssen","Jacobs","Veen","Bos","Bergman","Hendriks","Dekker","Mulder","Willems","Meijer","Graaf","Leeuwen","Vermeulen","Koster","Peeters","Brouwer","Kok","Peters","Smits","Linden","Vliet","Wit","Beekman","Bosch","Meer","Koning","Beek","Haan","Vermeer","Verhoeven","Bruijn","Jonge","Heuvel","Martens","Dam","Hoek","Pieters","Walle","Bruin","Timmermans","Prins","Wouters","Janssens","Blom","Velde","Loon","Lange","Maas","Mol","Dijkstra","Post","Wal","Maes","Dieleman","Hermans","Jager","Stam","Gerrits","Groen","Roos","Wijk","Kuiper","Broek","Leeuw","Lambert","Kroon","Verdonck","Geerts","Boon","Hoekstra","Schouten","Gastel","Brink","Goossens","Steen","Bleijenberg","Bijl","Dubois","Jonker","Rooij","Driel","Pol","Ruiter","Stevens","Horst","Verbeek","Mertens","Ende","Sanders","Driessen","Huisman","Kooij","Schipper","Waal","Laan","Scholten","Vink","Ven","Postma","Aerts","Santen","Roovers","Verhulst","Verschoor","Ham","Moerman","Rijn","Bax","Franken","Eijk","Martin","Bosman","Meulen","Veenstra","Mostert","Velden","Harms","Wolters","Zanten","Claes","Poot","Ridder","Ginkel","Doorn","Heijden","Oost","Os","Blok","Kramer","Simons","Kuipers","Rovers","Cornelis","Dupont","Valk","Zwart","Gerard","Verweij"]

    //first lets recreate all databases
    mysqlDs.automigrate(function(){
        console.log("tables recreated: let's seed");

        async.parallel({
            schools: async.apply(createSchools)
            // ....
        }, function(errFase1, resultsFase1) {
            if (errFase1) throw errFase1;

            async.parallel({
                groups: async.apply(createGroups, resultsFase1.schools),
                persons: async.apply(createStudents, resultsFase1.schools),
            }, function(errFase2, resultsFase2) {
                if (errFase2) throw errFase2;

                // ???????????????????????????????????

                // ??? HOW TO add a relation between the persons and the groups
                // a person must be able to live 
                // in multiple groups

            });
        });
    });

    function createSchools(cb) {
        var School = app.models.School;
        School.create([
            {
                "name": "Harvard",
                "address": "xxx",
                "zip": "0000",
                "place": "yyy"  
            },
            {
                "name": "Oxford",
                "address": "xxx",
                "zip": "0000",
                "place": "yyy"  
            }
        ], cb);
    }



    function createGroups(schools,cb) {
        var Group = app.models.Group;
        Group.create([
            { "name": "Class 1", "schoolId": schools[0].id },
            { "name": "Class 2", "schoolId": schools[0].id },
            { "name": "Class 3", "schoolId": schools[0].id },
            { "name": "Class 4", "schoolId": schools[0].id },
            { "name": "Class 5", "schoolId": schools[0].id },
            { "name": "Class 6", "schoolId": schools[0].id },
            { "name": "Class 1", "schoolId": schools[1].id },
            { "name": "Class 2", "schoolId": schools[1].id },
            { "name": "Class 3", "schoolId": schools[1].id },
            { "name": "Class 4", "schoolId": schools[1].id },
            { "name": "Class 5", "schoolId": schools[1].id },
            { "name": "Class 6", "schoolId": schools[1].id },
        ], cb);
    }

    function createStudents(schools,cb) {
        var Person = app.models.Person;
        var students = [];
        for (var i = 0; i < 240; i++) {
            chooseFrom = (i%2 == 1) ? girlsNames : boysNames ;
            students.push({
                "name": names[i%names.length],
                "firstName": chooseFrom[i%chooseFrom.length],
                "username": "student"+i,
                "password": "testje",
                "email": "student"+i+"@mailinator.com",
                "emailVerified": true,
                "schoolId": schools[Math.floor(i/120)].id
            });
        };
        Person.create(students, cb);
    }
};
我找不到关于这个具体问题的任何教程


我调试了bootscript,并检查了组变量,它是一个ModelConstructor。我猜我可以通过people()函数获取相关人员,但如何将人员添加到特定组?

在该组中找到了正确的文档:


//需要传递的id不是整个实例。甚至loopbackjs文档也需要更新

var student = students[0];
Group.findOne(function(err, group){
console.log(group);
group.people.add(student.id); // <--- id and not instance
})
var student=students[0];
Group.findOne(函数(err,Group){
控制台日志(组);

group.people.add(student.id);//我正在处理相同的问题。在获取环回以生成直通表时是否遇到任何问题?我得到的是“无法设置未定义的属性{MODEL}id”错误,我认为这与环回未生成存储多对多关系的表有关。我对此没有问题。调用automigrate()在我的数据源上,这是自动为我做的。我不认为这是与数据库相关的问题,因为这会引发MySQL错误。在关系定义中,modelName设置是否正确?de model-config.js中的模型设置是否正确?
var student = students[0];
Group.findOne(function(err, group){
console.log(group);
group.people.add(student.id); // <--- id and not instance
})