続編に問題があります。これが私がやろうとしていることです:
return pointsTransaction.findAndCountAll({
where:{
user_id: userId
},
limit: opts.limit,
offset: opts.offset,
include:[{
model:sequelize.models.pointsPendingtransaction
}]
});
生成されたクエリは次のようになります。
SELECT "pointsTransaction".*,
"pointsPendingtransactions"."transaction_ptr_id" AS "pointsPendingtransactions.transactionPtrId",
"pointsPendingtransactions"."is_active" AS "pointsPendingtransactions.isActive",
"pointsPendingtransactions"."transaction_id" AS "pointsPendingtransactions.transaction_id"
FROM (
SELECT "pointsTransaction"."id",
"pointsTransaction"."date_time" AS "dateTime",
"pointsTransaction"."details",
"pointsTransaction"."points",
"pointsTransaction"."user_id"
FROM "points_transaction" AS "pointsTransaction"
WHERE "pointsTransaction"."user_id" = 10002 LIMIT 1000
) AS "pointsTransaction"
LEFT OUTER JOIN "points_pendingtransaction" AS "pointsPendingtransactions"
ON "pointsTransaction"."id" = "pointsPendingtransactions"."transaction_id"
したがって、SQLでは、クエリの最後にその行を追加するだけで、次のように機能します。WHERE "pointsPendingtransactions"."transaction_id" IS null
だから私の質問は、どうすれば続編でそれを行うことができますか?私は多くの異なる方法を試しましたが、誰もうまくいきませんでした...
次にやってみてください
where: {
transaction_id: {
$eq: null
}
}
引き起こす IS NULL
return pointsTransaction.findAndCountAll({
where:{
user_id: userId
},
limit: opts.limit,
offset: opts.offset,
include:[{
model:sequelize.models.pointsPendingtransaction,
where: {
transaction_id: {
$eq: null
}
}
}]
});
Sequelize.OpのSequelizeのシンボル演算子を使用している場合は、...
return pointsTransaction.findAndCountAll({
where:{
user_id: userId
},
limit: opts.limit,
offset: opts.offset,
include:[{
model:sequelize.models.pointsPendingtransaction,
where: {
transaction_id: {
// "$eq" changes to "[Op.eq]"
[Op.eq]: null
}
}
}]
});