在开发的时候遇到一个问题,同样的SQL条件,两次查询结果不一致。
门店查询获取到76条数据,总数显示为0。
商家查询获取到10条数据,总是显示为76.
不同身份进入到接口,通过进行权限的限制set值,所获得的查询前置条件是一样的。如下
通过日志打印拿到两次查询的SQL
如下:
-- 开发测试商家会员列表
SELECT
c.id, c.nickname, c.birthday, c.avatar, ca.grade, c.gender, m.agent_id , ca.consumer_id, ca.merchant_id, ca.account_balance, ca.account_constant, ca.account_credits, ca.remark, ca.integral, ca.remaining_seconds, ca.balance, ca.label, ca.amount_of_gift
FROM consumer AS c
LEFT JOIN consumer_account AS ca ON c.id = ca.consumer_id
LEFT JOIN merchant AS m ON m.id = ca.merchant_id
WHERE ca.merchant_id = 2 GROUP BY ca.id order by ca.id LIMIT 10;
-- 开发测试门店会员列表
SELECT c.id, c.nickname, c.birthday, c.avatar, ca.grade, c.gender, m.agent_id , ca.consumer_id, ca.merchant_id, ca.account_balance, ca.account_constant, ca.account_credits, ca.remark, ca.integral, ca.remaining_seconds, ca.balance, ca.label, ca.amount_of_gift
FROM consumer AS c
LEFT JOIN consumer_account AS ca ON c.id = ca.consumer_id
LEFT JOIN merchant AS m ON m.id = ca.merchant_id
WHERE ca.merchant_id = 2 GROUP BY ca.id order by ca.id
很明显发现分页查询条件没有了,
看到代码里面是通过分页插件去执行分页的
然后在 开发测试门店会员列表
的SQL去page.getTotal()
得到值为0
因为分页插件的获取原理是
total:SELECT * FROM (查询SQL)
row:查询SQL拼接LIMIT语句
通过断点debug发现在构建分页的时候startPage
的size都是0
然后门店执行到SQL执行语句的时候变成了1
很明显,可以观察到门店与商家的差距是因为门店有额外去查询商家id作为查询条件这一操作,商家查询是直接从token里面拿的商家id。
将构建分页代码后移到查询语句处,优化代码查询得出结果,一致! 问题解决。
查询得出结果,一致! 问题解决。