找回密码
 注册账号

QQ登录

只需一步,快速开始

手机号码,快捷登录

手机号码,快捷登录

初学者课程:T3自学|T6自学|U8自学软件下载课件下载工具下载资料:通资料|U8资料|NC|培训|年结积分规则 | 使用常见问题Q&A
知识库:U8 | | NC | U9 | OA | 政务U8|U9|NCC|NC65|NC65客开|NCC客开新手必读 | 任务 | 快速增金币用友QQ群[微信群]
查看: 26076|回复: 16

[已解决] 单据模板中,用getColvalue取表体数据,但表体有多行,如何将取数结果求和?

[复制链接]
发表于 2013-11-6 10:47:54 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册账号

×
本帖最后由 u20_ 于 2013-12-5 21:58 编辑

单据模板中,用getColvalue取表体数据,但表体有多行,如何将取数结果求和?

已知的问题:
1.单据模板公式中没有sum
2.不能按照sql求和语句来写 ,比如getColvalue(table,sum(A),PK,id)
3.单据模板 不支持sql,也不支持聚合函数
发表于 2016-8-16 14:43:56 | 显示全部楼层
在ClientUi中加上
//获取子表金额合计
     private void setamt(BillEditEvent e){
          double total = 0;
        this.getBillCardPanel().setHeadItem( "allotamt", total);
        SalarycollBVO[] bvos = ( SalarycollBVO[]) this.getBillCardPanel().getBillData().getBodyValueVOs (SalarycollBVO.class .getName());
        double allotamt=0;
        for( int i = 0;i<=bvos. length-1;i++){
         allotamt+= bvos[i].getAmount().doubleValue();
        }
        this.getBillCardPanel().setHeadItem( "allotamt", allotamt);
     }
回复 点赞 拍砖

使用道具 举报

 楼主| 发表于 2020-8-26 13:53:01 | 显示全部楼层
ytimcq 发表于 2020-8-20 10:35
我已经做了补丁,https://download.csdn.net/download/ytimcq/12731895

发帖的时候用的还是57,用友北京总部根本不管,要么就付费二开(这还是在产品没交付完的情况)
实在没有办法,就到数据库里做了个视图,当作变通解决方案



现在升到65,不仅补丁加密,依然还是吃相难看,服务期内都是一副你来咬我啊....
1.jpg

他们早已经不是那个用心做产品的用户之友,还给他们开发什么的补丁
这些坑货就应该推到在地,然后再踩上几脚,最后一脚把它踢进历史的阴沟
回复 点赞 拍砖

使用道具 举报

 楼主| 发表于 2016-2-4 09:46:42 | 显示全部楼层
zhougeqiu 发表于 2016-1-20 14:56
请问你的视图是如何做的  做好视图后又如何取数?

创建视图的sql语句要看你用的sql server还是oracle  貌似语法有些差异,大体上就像这样
create view test_tabals_sum as   select gno,sum(amount) from goods_in where goods_in.gno=goods...


系统自带的公式getColvalue(table,column,PK,id)  实际是不分表和视图的,只要把那个table指向新增的视图, 其他关键字也对应到视图就好了
回复 点赞 拍砖

使用道具 举报

 楼主| 发表于 2016-2-4 09:39:11 | 显示全部楼层
湖北川柏 发表于 2015-5-12 08:39
模板字段中自带有小计功能

模板字段中自带有小计功能  仅仅是对表体字段的合计,并且这只是一个显示效果,根本不会存储到数据库中

在有复杂的多表体表格中跨表体取合计,或者表头要取表体合计时,就没法用这个功能

回复 点赞 拍砖

使用道具 举报

发表于 2016-1-20 14:56:18 | 显示全部楼层
u20_ 发表于 2013-12-2 11:13
居然没有人回复,算了直接写个视图算了,国产软件,烂就一个字啊

请问你的视图是如何做的  做好视图后又如何取数?

点评

创建视图的sql语句要看你用的sql server还是oracle 貌似语法有些差异,大体上就像这样 create view test_tabals_sum as select gno,sum(amount) from goods_in where goods_in.gno=goods... 系统自带的公式  详情 回复 发表于 2016-2-4 09:46
回复 点赞 拍砖

使用道具 举报

 楼主| 发表于 2013-11-18 09:40:32 | 显示全部楼层
回复 点赞 拍砖

使用道具 举报

 楼主| 发表于 2013-12-2 11:13:46 | 显示全部楼层
居然没有人回复,算了直接写个视图算了,国产软件,烂就一个字啊

点评

请问你的视图是如何做的 做好视图后又如何取数?  详情 回复 发表于 2016-1-20 14:56
回复 点赞 拍砖

使用道具 举报

发表于 2013-12-2 13:56:37 | 显示全部楼层
全傻瓜式不是体现不了你的价值嘛,写视图后,用取值公式能解决。
回复 点赞 拍砖

使用道具 举报

发表于 2013-12-17 17:59:19 | 显示全部楼层
上面各位说的我都江堰市不懂,只能是学习吧
回复 点赞 拍砖

使用道具 举报

发表于 2014-1-12 15:27:22 | 显示全部楼层
貌似没有这种功能
回复 点赞 拍砖

使用道具 举报

发表于 2014-8-20 23:05:40 | 显示全部楼层
回复 点赞 拍砖

使用道具 举报

发表于 2015-5-12 08:39:34 | 显示全部楼层
模板字段中自带有小计功能

点评

模板字段中自带有小计功能 仅仅是对表体字段的合计,并且这只是一个显示效果,根本不会存储到数据库中 在有复杂的多表体表格中跨表体取合计,或者表头要取表体合计时,就没法用这个功能  详情 回复 发表于 2016-2-4 09:39
回复 点赞 拍砖

使用道具 举报

发表于 2016-8-23 08:42:11 | 显示全部楼层
回复 点赞 拍砖

使用道具 举报

发表于 2016-9-28 14:27:06 | 显示全部楼层
国产的就坚持着用吧
回复 点赞 拍砖

使用道具 举报

发表于 2020-8-20 10:35:08 | 显示全部楼层
我已经做了补丁,https://download.csdn.net/download/ytimcq/12731895

点评

发帖的时候用的还是57,用友北京总部根本不管,要么就付费二开(这还是在产品没交付完的情况) 实在没有办法,就到数据库里做了个视图,当作变通解决方案 现在升到65,不仅补丁加密,依然还是吃相难看,服务期内  详情 回复 发表于 2020-8-26 13:53
回复 点赞 拍砖

使用道具 举报

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

本版积分规则

QQ|站长微信|Archiver|手机版|小黑屋|用友之家 ( 蜀ICP备07505338号|51072502110008 )

GMT+8, 2024-5-7 16:15 , Processed in 0.033079 second(s), 11 queries , Gzip On, Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表