多对多关系连接表上的sails.js额外字段

Ale*_*nts 5 mysql sql node.js sails.js waterline

我有两个模型:

订单.js

module.exports = {
    attributes: {
        //Id is generated by mongo and is a primary key
        address: {
            type: 'string',
            required: true,
            size: 1000
        },
        status: {
            type: 'string',
            required: true,
            size: 15,
            defaultsTo: 'pending',
            enum: ['pending', 'processing', 'cancelled']
        },
        total: {
            type: 'string',
            required: true,
            size: 50
        },
        menues: {
            collection: 'menu',
            via: 'orders',
            dominant: true
        },
        customer: {
            model: 'customer'
        }
    }
};
Run Code Online (Sandbox Code Playgroud)

Menu.js

module.exports = {
    attributes: {
        //Id is generated by mongo
        name: {
            type: 'string',
            required: true,
            size: 255
        },
        description: {
            type: 'string',
            required: true,
            size: 1000
        },
        price: {
            type: 'string',
            required: true,
            size: 15
        },
        picture: {
            type: 'string',
            size: 255
        },
        //Relations
        orders: {
            collection: 'order',
            via: 'menues'
        }
    }
};
Run Code Online (Sandbox Code Playgroud)

有一个多对多的关系,它完美地工作并创建了一个menu_orders__order_menues集合,一切都很好。

但是我需要按顺序保存每个菜单的数量。就像菜单 ID“1”数量是 2 等。

所以一个额外的数据是数量:每个订单应该有每个菜单的确定数量

这样做的最佳方法是什么,以及如何将其存储在数据库中?我想以某种方式将它存储在关系表中,但我不知道如何。

请让我知道最正确和可接受的解决方案。

PS我目前使用sails-mongo,但很快就会迁移到MySQLPostgres,所以我需要以相对方式完成这项工作。

Naz*_*zar 2

将字段添加quantity到您的菜单模型架构中,并可以使用afterCreate函数为其设置值。

订单.js

module.exports = {
    attributes: {
        address: {
            type: 'string',
            required: true,
            size: 1000
        },
        status: {
            type: 'string',
            required: true,
            size: 15,
            defaultsTo: 'pending',
            enum: ['pending', 'processing', 'cancelled']
        },
        total: {
            type: 'string',
            required: true,
            size: 50
        },
        menues: {
            collection: 'menu',
            via: 'orders',
            dominant: true
        },
        customer: {
            model: 'customer'
        }
    },
    afterCreate: function (order, cb) {
        Menu.find(order.menues, function (err, menues) {
            if (err) return cb(err);
            async.each(menues, function (menu, next) {
                menu.quantity++;
                menu.save(next);
            }, cb);
        });
    }
};
Run Code Online (Sandbox Code Playgroud)

菜单.js

module.exports = {
    attributes: {
        name: {
            type: 'string',
            required: true,
            size: 255
        },
        description: {
            type: 'string',
            required: true,
            size: 1000
        },
        price: {
            type: 'string',
            required: true,
            size: 15
        },
        picture: {
            type: 'string',
            size: 255
        },
        quantity: {
            type: 'number',
            defaultsTo: 0
        },
        orders: {
            collection: 'order',
            via: 'menues'
        }
    }
};
Run Code Online (Sandbox Code Playgroud)

这不是一个完整的解决方案。你也必须处理afterUpdateafterDestroy发挥作用。