跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • postgre 排序问题
未分類
3 9 月 2020

postgre 排序问题

postgre 排序问题

資深大佬 : HashV2 5

django 站点

使用 Orderingfilter 和 PageNumberPagination 做排序和分页

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

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

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

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

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

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

大佬有話說 (6)

  • 主 資深大佬 : HashV2

    django 社区一直强推 postgres

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

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

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

    心态爆炸~~

  • 資深大佬 : xiaolinjia

    是不是 orm 用了 values 或者 distinct 之类的?

  • 主 資深大佬 : HashV2

    已经解决 匿了

  • 資深大佬 : neoblackcap

    假如你说的是你引用的那个情况,那么我可以告诉你,pg 的实现才是对的,引入了 window 函数。mysql 那种就是扯淡实现,一般出现在瞎用 order by 的情况下。SQL 严谨一点的 pg,你压根就不能实现查询。mysql 居然随机给你一个结果。

  • 主 資深大佬 : HashV2

    @neoblackcap 是这样的 一个表内假设有 fields1 -fields5 字段
    我使用 fields1 和 fields2 做排序的条件
    在排序条件不变的情况下 update 一条数据的 fields3 字段
    再次执行查询后 mysql 中和之前查询的结果是相同的 但是 pg 的查询结果就变了
    我只能在所有的查询 order by 中额外添加 id 排序
    还好有个自增的 id 字段 如果是 uuid 的话这种查询会不会影响查询性能?

  • 資深大佬 : neoblackcap

    @HashV2 你的 field1, field2 有 null 值么?要你指定的哦,只是 order by 是不应该出现你说的情况的。如果可以的话,你发一下 SQL

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

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具