从相关表(模型)中获取数据

时间:2015-11-24 07:17:49

标签: mysql node.js sequelize.js

我们说我有这些表格:

countries
    id - integer
    name - string

users
    id - integer
    countryId - integer
    name - string

我想要的是让所有用户使用他们的国家/地区名称而不是国家ID ... Sequelize文档很好,但令人困惑......

我得到以下功能以获取所有用户:

function get( request, response ) {

    models.users.findAll( {

        order: [ [ request.query.orderBy, request.query.sort ] ]

    } ).then( function ( users ) {

        response.json( users );

    } );

}

这是我的users.js型号:

'use strict';
module.exports = function ( sequelize, DataTypes ) {

    var users = sequelize.define( 'users', {
        name: DataTypes.STRING( 50 ),
        countryId: DataTypes.INTEGER,
    }, {
        classMethods: {
            associate: function ( models ) {
                // associations can be defined here
            }
        }
    } );

    return users;

};

那么......在查询用户模型时,为了获取国家名称而不是id,我需要做什么?

2 个答案:

答案 0 :(得分:1)

User.belongsTo(Country)
User.findAll({ include: [Country] })

每个用户都有一个.country属性,您可以在其中获取名称 - 不可能将国家/地区名称直接添加到同一对象,因为您必须使用原始查询,或者之后格式化结果

答案 1 :(得分:1)

您必须先在模型中定义关联

'use strict';
module.exports = function ( sequelize, DataTypes ) {

var users = sequelize.define( 'users', {
    name: DataTypes.STRING( 50 ),
    countryId: DataTypes.INTEGER,
}, {
    classMethods: {
        associate: function ( models ) {
            users.belongsTo(models.countries, {foreignKey: countryId})
        }
    }
} );

return users;

};

然后,您可以使用include:

进行查询
models.users.findAll( {

    order: [ [ request.query.orderBy, request.query.sort ] ],
    include: [{
        model: models.countries
    }]
} ).then( function ( users ) {

    // do some formating on the output

} );

如果您只想要country_name。

,可以格式化输出