Я хочу изменить структуру данных, возвращаемую запросом orm.Всего четыре таблицы.product
, category
- это отношения многие-ко-многим, есть таблица product_category
, которая служит мостом, и всего четыре таблицы, включая таблицу department
.ассоциация выглядит следующим образом:
// product
product.belongsToMany(models.category, {
through: 'product_category',
foreignKey: 'product_id'
});
// product_category
product_category.belongsTo(models.product, {
foreignKey: 'product_id'
});
product_category.belongsTo(models.category, {
foreignKey: 'category_id'
});
// category
category.belongsToMany(models.product, {
through: 'product_category',
foreignKey: 'category_id'
});
category.belongsTo(models.department, {
foreignKey: 'department_id'
});
// department
department.hasMany(models.category, {
foreignKey: 'department_id'
});
Посредством вышеуказанной структуры таблицы получается следующий запрос для получения продуктов, соответствующих department_id
:
const query = await product.findOne({
where: { product_id: id },
include: {
model: category,
attributes: ['category_id', ['name', 'category_name']],
include: {
model: department,
attributes: ['department_id', ['name', 'department_name']]
}
},
attributes: []
});
const data = query.categories;
Полученные данные json следующие:
"data": [
{
"category_id": 1,
"category_name": "French",
"department": {
"department_id": 1,
"department_name": "Regional"
},
"product_category": {
"product_id": 1,
"category_id": 1
}
}
]
Я хочу сделать вышеуказанные данные следующим образом:
"data": [
{
"category_id": 1,
"category_name": "French",
"department_id": 1,
"department_name": "Regional"
}
]
Чтобы обработать данные, как указано выше, есть два способа изменить основанный на sql запрос ormи обработать значение product
в javascript.Однако, так как я изучил sql с помощью orm, я не знал первый метод, поэтому я решил использовать его как второй метод.
Первая попытка
Я сделал две попытки,Обратите внимание, что фреймворк использует koa.js.Первый выглядит следующим образом:
const query = await product.findOne({
where: { product_id: id },
include: {
model: category,
attributes: ['category_id', ['name', 'category_name']],
include: {
model: department,
attributes: ['department_id', ['name', 'department_name']]
}
},
attributes: []
});
const data = query.categories.map(
({ category_id, category_name, department }) => ({
category_id,
category_name,
department_id: department.department_id,
department_name: department.department_name
})
);
ctx.body = data;
Ниже тела:
"data": [
{
"category_id": 1,
"department_id": 1
}
]
.. ??Что-то странное, поэтому я немного изменяю возвращаемое значение:
({ category_id, category_name, department }) => ({
// category_id,
// category_name,
department_id: department.department_id,
department_name: department.department_name
})
Вывод значения json:
"data": [
{
"department_id": 1
}
]
И наоборот, вы аннотировали department_id
, department_name
:
({ category_id, category_name, department }) => ({
category_id,
category_name,
// department_id: department.department_id,
// department_name: department.department_name
})
Полученное значение json:
"data": [
{
"category_id": 1
}
]
Я не мог сделать это другим способом.
Вторая попытка
await product
.findOne({
where: { product_id: id },
include: {
model: category,
attributes: ['category_id', ['name', 'category_name']],
include: {
model: department,
attributes: ['department_id', ['name', 'department_name']]
}
},
attributes: []
})
.then(query => {
const data = query.categories.map(
({ category_id, category_name, department }) => ({
category_id,
category_name,
department_id: department.department_id,
department_name: department.department_name
})
);
ctx.body = data;
});
Обаметоды имеют одинаковые результаты, поэтому я не знаю, что делать.
Поэтому я сопоставляю переменную с вложенным массивом с данными json.Я получаю желаемый результат:
const data = {
categories: [
{
category_id: 1,
category_name: 'French',
department: { department_id: 1, department_name: 'Regional' },
product_category: { product_id: 1, category_id: 1 }
}
]
};
const product = data.categories.map(
({ category_id, category_name, department }) => ({
category_id,
category_name,
department_id: department.department_id,
department_name: department.department_name
})
);
console.log(product);
// [ { category_id: 1,
// category_name: 'French',
// department_id: 1,
// department_name: 'Regional' } ]
Так что я запутался.Как я могу обработать данные из запроса на продолжение?Буду очень признателен за вашу помощь.
Пожалуйста, дайте мне знать, если подход к решению проблемы неправильный или вам нужна схема модели.