butterfly CODE DEMO2( ABOUT SUM)

IDataQuery query = session.createDataQuery();
query.setTarget(session.getObjectDef("time_record"));

query.addFilter("hs_is_deleted", SATConstants.SQL_OP_EQUAL, Boolean.FALSE); //Boolean.FALSE

Long week_start_date_Long = new Long(week_start_date);
Long week_end_date_Long = new Long(week_end_date);
String l_date = week_start_date_Long.toString() + "," + week_end_date_Long.toString();
query.addFilter("occurred_date", SATConstants.SQL_OP_BETWEEN, l_date);

IUnaryFunction uf = session.createUnaryFunction(SATConstants.AGGRE_SUM, "hours_spent1"); //对hours_spent域做sum,将sum值存放在hours_spent1中
uf.setFieldDef(session.getObjectDef("time_record").getFieldDef("hours_spent"));
query.addField(uf);

query.addField("record_type");
query.addFilter("project", SATConstants.SQL_OP_EQUAL, projectOid);

IGroupBy gb = query.createGroupBy();
gb.setGroupByField(session.getObjectDef("time_record").getFieldDef("record_type"));
query.addGroupBy(gb);
    
IDataCollection dc = query.query(session);
double total=0;
while (dc.next()) {
  IBusObject bo = dc.getObject();
 
  double hours_spent=bo.getDoubleField("hours_spent1"); //通过hours_spent1获取sum值
  total+=hours_spent;

  String record_type="";
  int weight=0;
  IOption option=bo.getSingleSelection("record_type");
  if(option!=null){
   weight=option.getWeight(); 
   record_type = option.getText(lo_string);
  }
 
  Map m = new HashMap(4);
  m.put("record_type",record_type);
  m.put("weight",""+weight);
  m.put("hour_spent", ""+hours_spent);
  l.add(m);
}
dc.close();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值