二开获取yigo设计器里查询集合里中的某个SQL
package com.bokesoft.lrp_v3.mid.dongming.service; import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import com.bokesoft.yigo.common.util.TypeConvertor;
import com.bokesoft.yigo.mid.base.DefaultContext;
import com.bokesoft.yigo.mid.service.IExtService;
import com.bokesoft.yigo.struct.datatable.DataTable;
import com.bokesoft.yigo.struct.document.Document;
import com.bokesoft.yigo.struct.usrpara.Paras; public class CalOutPrintTable3 implements IExtService { //private String update = "update Lrp_wmtx_h set OutPrint=33 where salesOrderNumber=?"; @Override
public Object doCmd(DefaultContext context, ArrayList<Object> arg1) throws Throwable {
// TODO Auto-generated method stub
Date d1 = TypeConvertor.toDate(arg1.get(0));
Date d2 = TypeConvertor.toDate(arg1.get(1));
Long SalesAdderss = TypeConvertor.toLong(arg1.get(2));
Long warehousecenterid = TypeConvertor.toLong(arg1.get(3));
Map<String, String> map = createsql(context, arg1);
String query = map.get("query");
String type = map.get("type");
DataTable tt = null;
switch (type) {
case "f":
tt = context.getDBManager().execPrepareQuery(query, SalesAdderss, warehousecenterid, warehousecenterid);
break;
case "ff":
tt = context.getDBManager().execPrepareQuery(query, d1, d2, SalesAdderss, warehousecenterid,
warehousecenterid);
break;
case "fff":
tt = context.getDBManager().execPrepareQuery(query, d1, SalesAdderss, warehousecenterid, warehousecenterid);
break;
case "ffff":
tt = context.getDBManager().execPrepareQuery(query, d2, SalesAdderss, warehousecenterid, warehousecenterid);
System.out.println(query);
break;
}
Paras paras = new Paras();//类似于SetPara
paras.put("StandardCarweight", setlist(context, tt));
return caltable(context, tt);
} private String billno(DefaultContext context,Long SalesAdderss) throws Throwable {
String SalesOrderNumbers = "";
Document doc = context.getDocument();
DataTable t1 = doc.get("DomesticOutbound_C");
t1.setFilter("shipcustomerNum=="+SalesAdderss);
t1.filter();
while (t1.next()) {
if (t1.getInt("SelectField") == 1) {
String salesOrderNumber = TypeConvertor.toString(t1.getObject("SalesOrderNumber"));
SalesOrderNumbers = SalesOrderNumbers + ",'" + salesOrderNumber + "'";
}
}
String SalesOrderNumber = SalesOrderNumbers.substring(1, SalesOrderNumbers.length());
return SalesOrderNumber;
} private Map<String, String> createsql(DefaultContext context, ArrayList<Object> arg1) throws Throwable {
String query = context.getVE().getMetaFactory().getMetaForm("DomesticOutbound").getQueryCollection()
.get("PrintTable1").getStatements().get(0).getContent();//获取查询集合里的查询SQL context这里需要好好理解下
String nos = billno(context,TypeConvertor.toLong(arg1.get(2)));
query = query.replace("salesorderNO_para", nos);
Date d1 = TypeConvertor.toDate(arg1.get(0));
Date d2 = TypeConvertor.toDate(arg1.get(1));
String Datesql = " ";
String type = "f";
if (d1 != null && d2 != null) {
Datesql = " and h.createtime between ? and ? ";
type = "ff";
}
if (d1 != null && d2 == null) {
Datesql = " and h.createtime >=? ";
type = "fff";
}
if (d1 == null && d2 != null) {
Datesql = " and h.createtime <=? ";
type = "ffff";
}
query = query.replace("createtime_paras", Datesql);
Map<String, String> map = new HashMap<String, String>();
System.out.println(query);
map.put("query", query);
map.put("type", type);
return map;
} private DataTable caltable(DefaultContext context, DataTable tt) {
List<String> list = new ArrayList<String>();
tt.beforeFirst();
while (tt.next()) {
String taskNumber = tt.getString("TaskNumber");
String BatchNo = tt.getString("BatchNo");
if (BatchNo != null)
if (BatchNo.trim().length() != 0)
tt.setString("BatchNo", splitbatchaNo(BatchNo));
if (!tt.getString("Packing").equals("FCL")) {
if (tt.getNumeric("countqty").compareTo(BigDecimal.ZERO) == 0
&& tt.getNumeric("BoxUnitNum1").compareTo(BigDecimal.ZERO) == 0
&& tt.getNumeric("BoxNum1").compareTo(BigDecimal.ZERO) != 0)
tt.setString("Packing", "OTHER");
else {
tt.setString("BoxSeq",
taskNumber.substring(taskNumber.length() - 8, taskNumber.length() - 4) + "-" + TypeConvertor
.toInteger(taskNumber.substring(taskNumber.length() - 4, taskNumber.length())));
list.add(taskNumber);
}
}
}
System.out.println("打印出库单(更新打印状态)DataTable: "+tt);
return tt;
} private String splitbatchaNo(String BatchNo) {
String[] nos = BatchNo.split(",");
if (nos.length > 1)
BatchNo = nos[0] + "," + nos[1];
else
BatchNo = nos[0];
return BatchNo;
} private static BigDecimal calCarweight(List<String> list) {
List<String> newList = new ArrayList<String>();
for (String cd : list) {
if (!newList.contains(cd)) {
newList.add(cd);
}
}
return new BigDecimal(newList.size());
} private static BigDecimal setlist(DefaultContext context, DataTable tt) {
List<String> list = new ArrayList<String>();
tt.beforeFirst();
while (tt.next()) {
if (!tt.getString("Packing").equals("FCL") && !tt.getString("Packing").equals("OTHER"))
list.add(tt.getString("taskNumber"));
}
return calCarweight(list);
}
}
二开获取yigo设计器里查询集合里中的某个SQL的更多相关文章
- 解析大型.NET ERP系统核心组件 查询设计器 报表设计器 窗体设计器 工作流设计器 任务计划设计器
企业管理软件包含一些公共的组件,这些基础的组件在每个新项目立项阶段就必须考虑.核心的稳定不变功能,方便系统开发与维护,也为系统二次开发提供了诸多便利.比如通用权限管理系统,通用附件管理,通用查询等组件 ...
- 基于Extjs的web表单设计器 第七节——取数公式设计之取数公式的使用
基于Extjs的web表单设计器 基于Extjs的web表单设计器 第一节 基于Extjs的web表单设计器 第二节——表单控件设计 基于Extjs的web表单设计器 第三节——控件拖放 基于Extj ...
- YbSoftwareFactory 代码生成插件【十六】:Web 下灵活、强大的审批流程实现(含流程控制组件、流程设计器和表单设计器)
程序=数据结构+算法,而企业级的软件=数据+流程,流程往往千差万别,客户自身有时都搞不清楚,随时变化的情况更是家常便饭,抛开功能等不谈,需求变化很大程度上就是流程的变化,流程的变化会给开发工作造成很大 ...
- 如何在CRM系统中集成ActiveReports最终报表设计器
有时候,将ActiveReports设计器集成到业务系统中,为用户提供一些自定义的数据表,用户不需要了解如何底层的逻辑关系和后台代码,只需要选择几张关联的数据表,我们会根据用户的选择生成可供用户直接使 ...
- 通过用 .NET 生成自定义窗体设计器来定制应用程序
通过用 .NET 生成自定义窗体设计器来定制应用程序 https://www.microsoft.com/china/MSDN/library/netFramework/netframework/Cu ...
- Springboot2集成Activiti设计器并去除security
前言 鉴于项目需要将acitiviti设计器整合到原工程中,在网上查了不少资料都不太适用,经过借鉴和自己倒腾终于搞定了,分享一下经验,如果有问题,可以在留言区咨询. 文中用到的资源代码链接: http ...
- ActiveReports 9 新功能:可视化查询设计器(VQD)介绍
在最新发布的ActiveReports 9报表控件中添加了多项新功能,以帮助你在更短的时间里创建外观绚丽.功能强大的报表系统,本文将重点介绍可视化数据查询设计器,无需手动编写任何SQL语句,主要内容如 ...
- Activiti(二) springBoot2集成activiti,集成activiti在线设计器
摘要 本篇随笔主要记录springBoot2集成activiti流程引擎,并且嵌入activiti的在线设计器,可以通过浏览器直接编辑出我们需要的流程,不需要通过eclipse或者IDEA的actiB ...
- C# 文件里的类不能进行设计,因此未能为该文件显示设计器
C# 文件里的类不能进行设计,因此未能为该文件显示设计器 vs 一直打不开设计界面 仅仅能查看代码界面 这时候须要查看 代码中 是不是 从 form 继承 假设不是 窗口类型 改为 fo ...
随机推荐
- linux命令学习笔记(26):用SecureCRT来上传和下载文件
用SSH管理linux服务器时经常需要远程与本地之间交互文件.而直接用SecureCRT自带的上传下载功能无疑是最方便的,SecureCRT下的文件传输协议有ASCII.Xmodem.Zmodem. ...
- Mac使用记录
---恢复内容开始--- brew list //查看brew安装东东 ls //当前目录下内容 brew --cache //查看brew下载目录 /usr/local/Cellar/ //隐藏文件 ...
- BZOJ3295:[CQOI2011]动态逆序对
浅谈树状数组与线段树:https://www.cnblogs.com/AKMer/p/9946944.html 题目传送门:https://www.lydsy.com/JudgeOnline/prob ...
- Asp.Net 无法获取IIS拾取目录的解决办法[译]
Asp.Net 无法获取IIS拾取目录的解决办法 作者:Jason Doucette [MCP] 翻译:彭远志 原文地址:Fixing the cannot get IIS pickup direc ...
- 【转】值得推荐的C/C++框架和库
偶然间在博客园前辈那里看到的,转载备用,日后研究. 原文链接:http://www.cnblogs.com/findumars/p/6891515.html Webbench是一个在linux下使用的 ...
- 面向对象(this关键字)
package com_package2; public class Person3 { private int age; private String name; public int getAge ...
- IOS推流 搭建环境
效果图 iTools有点卡, 但是推到服务器倒是很快的. 推流 前言 这篇blog是iOS视频直播初窥:<喵播APP>的一个补充. 因为之前传到github上的项目中没有集成视频的推流.有 ...
- HDU 3549 Flow Problem (最大流ISAP)
Flow Problem Time Limit: 5000/5000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Tota ...
- usb资料2
ubuntu linux下如何在启动时就关闭usb接口? https://zhidao.baidu.com/question/548651197.html Linux USB 驱动开发(四)—— 热插 ...
- JEECMS-新闻内容中遍历批量上传的图片
[#list content.pictures as p] <li value="${p_index+1}"> <img src="${p.imgPat ...