免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: send_linux
打印 上一主题 下一主题

开源数据库不一样的声音!您所不了解的PostgreSQL!(获奖名单已公布-2012-5-23) [复制链接]

论坛徽章:
0
61 [报告]
发表于 2012-04-12 17:11 |只看该作者
回复 30# haterw



应用程序是java , procedural 处理数据,量较大,怎么让java 端得到当前处理进度,  我的做法是处理过程中更新一个进度字段,java 不断的获取此值,但是一次procedural 调用,是在一个transaction 中, 所以java 进度值 ,怎么办????


   

论坛徽章:
0
62 [报告]
发表于 2012-04-12 21:36 |只看该作者
sytpb 发表于 2012-04-12 17:11
回复 30# haterw


我们有个东西也是相似的需求,现在用的是把进度写在一个文件里进行交换,不过有时会出现文件的读写冲突,始终还是没有比较完美的方案。

论坛徽章:
0
63 [报告]
发表于 2012-04-13 07:54 |只看该作者
用sequence,直接读取sequence的last_value列来获得进度。回复 66# sytpb


   

论坛徽章:
0
64 [报告]
发表于 2012-04-13 10:14 |只看该作者
回复 69# nozjz



这个sequence 可以吗,不太理解这个东西。


   

论坛徽章:
0
65 [报告]
发表于 2012-04-13 10:32 |只看该作者
回复 68# ywpeng


    哦,谢谢,看来不只我一个人遇到这样的问题。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
66 [报告]
发表于 2012-04-13 13:13 |只看该作者
后面调用存储过程,前面用户端界面想显示进度表,达不到这样的效果,不是POSTGRESQL数据库的问题吧,

你用ORACLE ,DB2,SQL SERVER,MY SQL试试,它们能提供什么好办法?

我想这样的问题我,只能想想出二个办法:

1)不要用存储过程,直接用前端编程语言实现数据处理。

2)如果非要用存存储过程,那么可以设计一个临时表,该表包含当前记录,和总记录,每处理一条数据,存储过程则把这个表的当前记录数更新,
然后,前端界面用一个多线程,不停地读取这个临时表的数据。达到显示进度条这个效果。



论坛徽章:
0
67 [报告]
发表于 2012-04-13 14:15 |只看该作者
回复 72# tony_trh


    关于第一情况不说了。第二种情况,我上面说过,postgresql proceduaral 是在一个transaction 中完成,所以过程中是取不到progress,只有完成时,才能查询出来,这时肯定就是100% 。

论坛徽章:
1
技术图书徽章
日期:2014-07-11 16:30:58
68 [报告]
发表于 2012-04-13 14:19 |只看该作者
PG 用的多么? 没用过呀,不太了解。呵呵。看看大家的回复吧 。学习一下。  db2 用的多么?

论坛徽章:
0
69 [报告]
发表于 2012-04-13 20:16 |只看该作者
之前还看过一段时间的pg的代码的。可惜现在工作用不上了。很少接触了。

论坛徽章:
0
70 [报告]
发表于 2012-04-13 20:54 |只看该作者
应该能满足你的要求,sequence的行为类似于脏读  回复 70# sytpb


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP