有 user表,role表,然后user和role建立了多对多的关系 代码是这样的
let user = await models.User.findOne({
where: {id: id},
attributes: ['name','id']
});
let roles = await user.getRoles({
attributes: ['name','id'],
raw: true
});
user和role数据都是能取到的,user 的 attributes也是生效的, 但是roles 的就不行了,role表本身的字段能过滤,但是不知道为什么一定会带上user与role 的关系数据
大概就是我想要的是这样的数据
{
id: 1,
name: '管理员'
}
却给了我这样的数据
{
id: 1,
name: '管理员',
'userRole.createdAt': 2016-09-02T09:43:07.714Z,
'userRole.updatedAt': 2016-09-02T09:43:07.714Z,
'userRole.userId': 1,
'userRole.roleId': 1
}
看文档也没找到解决的办法 http://docs.sequelizejs.com/en/v3/
model里是不是定义了get function
联表查询,用include
定义时用hasMany 查询用include
@mosaic101 include 和他有关联的表是怎么查?
include 和他有关联的表是怎么查?
@qingmingsang 文档写的很详细,看看就懂了
你定义实体的时候,关系建立了么
建立了的。
你好,你这个问题解决了吗,我也遇到同样的问题
似乎是打印和输出到body里的数据有差异
@qingmingsang 这个问题我解决了,我在sequelize的github下的issue下,官方的回答是,多对多关系时用belongstomany通过attributes去除关系表的数据清除不了,这个一个bug,要在sequelize第四个版本修复。我现在是通过hasMany和belong来建立多对多关系的,完美解决现在的问题
@jiapeiyang 你说的这个issue我也看过,可能是后面我不怎么用belongstomany关系了就没遇到了