postgre 排序问题

2020-09-16 15:01:36 +08:00
 HashV2

django 站点

使用 Orderingfilter 和 PageNumberPagination 做排序和分页

之前使用 mysql 一切 ok, 但是从 mysql 迁移到 postgresql 之后发现了一个诡异的问题

当我在某页对某一条数据进行操作,操作会改变这条数据的状态字段(但并未使用状态字段进行排序)

操作完成后刷新页面,发现当前页的数据发生了变化,升级的那条数据不见了

这搞得我没法在一个页面展示一组稳定数据

再次强调,在 mysql 上的时候没有此问题

可能跟这个有点像 https://www.v2ex.com/t/663098

1312 次点击
所在节点    Python
6 条回复
HashV2
2020-09-16 15:08:15 +08:00
django 社区一直强推 postgres

本来使用的 mysql,有一些数组和 json 字段用 mysql 的 textfield 存 感觉没有 postgres 来的爽 就做了一次迁移

刚迁移过来的时候也做了测试 但是没测的很详细

结果用了一个多星期开发的都差不多了, 给我整这么一出幺蛾子 心态爆炸 这两天如果解决不了估计要再迁移回 mysql 了

心态爆炸~~
xiaolinjia
2020-09-16 15:32:06 +08:00
是不是 orm 用了 values 或者 distinct 之类的?
HashV2
2020-09-16 15:35:49 +08:00
已经解决 匿了
neoblackcap
2020-09-16 21:03:10 +08:00
假如你说的是你引用的那个情况,那么我可以告诉你,pg 的实现才是对的,引入了 window 函数。mysql 那种就是扯淡实现,一般出现在瞎用 order by 的情况下。SQL 严谨一点的 pg,你压根就不能实现查询。mysql 居然随机给你一个结果。
HashV2
2020-09-17 11:08:11 +08:00
@neoblackcap 是这样的 一个表内假设有 fields1 -fields5 字段
我使用 fields1 和 fields2 做排序的条件
在排序条件不变的情况下 update 一条数据的 fields3 字段
再次执行查询后 mysql 中和之前查询的结果是相同的 但是 pg 的查询结果就变了
我只能在所有的查询 order by 中额外添加 id 排序
还好有个自增的 id 字段 如果是 uuid 的话这种查询会不会影响查询性能?
neoblackcap
2020-09-17 16:58:01 +08:00
@HashV2 你的 field1, field2 有 null 值么?要你指定的哦,只是 order by 是不应该出现你说的情况的。如果可以的话,你发一下 SQL

另外 uuid 类型一般是有优化的,不会造成很大的影响。记得不要存成字符型就可以了,存成字符型就没救

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/707578

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX