从相关表(模型)中获取数据 sequelize
Get the data from related tables (models) sequelize
假设我有这些表:
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?
User.belongsTo(Country)
User.findAll({ include: [Country] })
每个用户都会有一个 .country
属性,您可以在其中获取名称 - 无法将国家/地区名称直接添加到同一对象中,因为您必须这样做使用原始查询,或之后格式化结果
您必须先在模型中定义关联
'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.
,你可以格式化你的输出
假设我有这些表:
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?
User.belongsTo(Country)
User.findAll({ include: [Country] })
每个用户都会有一个 .country
属性,您可以在其中获取名称 - 无法将国家/地区名称直接添加到同一对象中,因为您必须这样做使用原始查询,或之后格式化结果
您必须先在模型中定义关联
'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.
,你可以格式化你的输出