django 站点
使用 Orderingfilter 和 PageNumberPagination 做排序和分页
之前使用 mysql 一切 ok, 但是从 mysql 迁移到 postgresql 之后发现了一个诡异的问题
当我在某页对某一条数据进行操作,操作会改变这条数据的状态字段(但并未使用状态字段进行排序)
操作完成后刷新页面,发现当前页的数据发生了变化,升级的那条数据不见了
这搞得我没法在一个页面展示一组稳定数据
再次强调,在 mysql 上的时候没有此问题
可能跟这个有点像 https://www.v2ex.com/t/663098
1
HashV2 OP django 社区一直强推 postgres
本来使用的 mysql,有一些数组和 json 字段用 mysql 的 textfield 存 感觉没有 postgres 来的爽 就做了一次迁移 刚迁移过来的时候也做了测试 但是没测的很详细 结果用了一个多星期开发的都差不多了, 给我整这么一出幺蛾子 心态爆炸 这两天如果解决不了估计要再迁移回 mysql 了 心态爆炸~~ |
2
xiaolinjia 2020-09-16 15:32:06 +08:00
是不是 orm 用了 values 或者 distinct 之类的?
|
3
HashV2 OP 已经解决 匿了
|
4
neoblackcap 2020-09-16 21:03:10 +08:00
假如你说的是你引用的那个情况,那么我可以告诉你,pg 的实现才是对的,引入了 window 函数。mysql 那种就是扯淡实现,一般出现在瞎用 order by 的情况下。SQL 严谨一点的 pg,你压根就不能实现查询。mysql 居然随机给你一个结果。
|
5
HashV2 OP @neoblackcap 是这样的 一个表内假设有 fields1 -fields5 字段
我使用 fields1 和 fields2 做排序的条件 在排序条件不变的情况下 update 一条数据的 fields3 字段 再次执行查询后 mysql 中和之前查询的结果是相同的 但是 pg 的查询结果就变了 我只能在所有的查询 order by 中额外添加 id 排序 还好有个自增的 id 字段 如果是 uuid 的话这种查询会不会影响查询性能? |
6
neoblackcap 2020-09-17 16:58:01 +08:00
@HashV2 你的 field1, field2 有 null 值么?要你指定的哦,只是 order by 是不应该出现你说的情况的。如果可以的话,你发一下 SQL
另外 uuid 类型一般是有优化的,不会造成很大的影响。记得不要存成字符型就可以了,存成字符型就没救 |