免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2872 | 回复: 8
打印 上一主题 下一主题

POSTGRESQL,一个很棘手的问题 [复制链接]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-08 08:05 |只看该作者 |倒序浏览
遇到一个很棘手的问题,没办法解决,不知道有哪位高手知道:
建立一个表,比如有CODE,NAME,SALARY几个字段,CODE为主键,
然后追加数据到表中,比如:
CODE                 NAME            SALALRY
-------------------------------------------------
001               AAAAA                     1000
002              BBBBBB                  3500
003            CCCCC                            5000
004           DDDDDD                         2000

当修改002的SALARY后,该记录就会移动位置,跑到最后的位置去了,变成:

CODE                 NAME            SALALRY
-------------------------------------------------
001               AAAAA                     1000
003            CCCCC                            5000
004           DDDDDD                         2000
002              BBBBBB                  3500


这给实际应用造成很大的麻烦,我希望它能像SQL SERVER 那样,修改非主键时候,依然,保持原来的位置,不然,会造成数据顺序很乱,
我给人事部设计的一个考勤录入,经常一修改数据,位置就变动,造成文员不能按照纸质的表格来对数了,很麻烦,

不知道有哪位高手能解决这个问题呢?

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
2 [报告]
发表于 2011-12-08 08:49 |只看该作者
这个可能是PG内部排序记录的问题吧(总是把更新时间最新的放在后面)。
最好的办法你可以在你的SQL文加上按CODE升序排序就可以了。

论坛徽章:
7
数据库技术版块每日发帖之星
日期:2015-08-08 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-09-18 06:20:00数据库技术版块每周发帖之星
日期:2015-11-06 19:56:51数据库技术版块每日发帖之星
日期:2016-01-22 06:20:00数据库技术版块每日发帖之星
日期:2016-02-05 06:20:00
3 [报告]
发表于 2011-12-08 13:43 |只看该作者
本帖最后由 asdf2110 于 2011-12-08 13:45 编辑

这个是 PG 的多版本并发控制(MVCC)的机制,修改数据时实际新插入了一条元组,把原来的元组标记为不可见,等到做vacuum时,才会把对所有事务都不可见的元组删除掉,把它后面的元组依次前移。
在查询最后加上 ORDER BY CODE ASC,顺序就不会变了。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2011-12-08 15:12 |只看该作者
这给开发客户端软件,带来不大不小的烦恼。

论坛徽章:
0
5 [报告]
发表于 2011-12-08 22:00 |只看该作者
哪些2b开发的客户端软件。竟然有依赖物理顺序的。

论坛徽章:
0
6 [报告]
发表于 2011-12-10 07:09 |只看该作者
你的软件要改.  这是上策

论坛徽章:
0
7 [报告]
发表于 2011-12-19 23:53 |只看该作者
是客户端程序的问题,关系型数据库并不保证查询返回的是物理存储数据,只是竟可能的快返回,如果命中缓存的话直接返回的是缓存的数据,依赖存储顺序完全的不靠谱

论坛徽章:
0
8 [报告]
发表于 2011-12-20 13:44 |只看该作者
希望楼主早日找到答案

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
9 [报告]
发表于 2011-12-21 21:33 |只看该作者
包括ORACLE来说,很多时候想排序都必须显示的进行排序操作。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP