- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用操作、 Controller 、servlet struts 框架编写 Excel 报告。该报告非常拥挤,已经有大约 10 个单独的查询。由于报告发生变化,我需要再添加大约 10 个查询。有没有办法做到这一点而不必继续嵌套结果集?以下是现有代码。
public TotalSalesKPIContainer totalSalesKPIQuery(String franchiseId, java.util.Date startDate, java.util.Date stopDate) {
String getFranIds = null;
ArrayList storeResultList = new ArrayList();
ArrayList salesPersonResultList = new ArrayList();
TotalSalesKPIContainer result = null;
Connection conn = null;
PreparedStatement pstmt1, pstmtLY, pstmtCountLY, pstmtTCount, pstmtTCountLY, pstmtCount = null;
PreparedStatement pstmt, ps = null;
ResultSet rs1, rsLY, rsCountLY, rsTCount, rsTCountLY, rsCount = null;
ResultSet rs = null, rsSP = null, rsBySP, rsTCount2, rsTCountLY2 = null, rsBySPLY, rsCountLY2, rsCount2;
java.util.Date prevStartDate;
java.util.Date prevStopDate;
try {
conn = getConnection();
if (franchiseId.equals("0")) {
getFranIds = "Select id, name from vymac.organization";
pstmt = conn.prepareStatement(getFranIds);
} else {
getFranIds = "Select id, name from vymac.organization where id = ? ";
pstmt = conn.prepareStatement(getFranIds);
pstmt.setString(1, franchiseId);
}
int franID = Integer.parseInt(franchiseId);
rs = pstmt.executeQuery();
while (rs.next()) {
result = new TotalSalesKPIContainer(rs.getString(2), franID,startDate, stopDate, storeResultList,salesPersonResultList);
/*
* This section is for Salesperson total sales
*/
pstmt1 = conn.prepareStatement(getTotalSalesBySP);
pstmt1.setInt(1, rs.getInt(1));
pstmt1.setDate(2, new java.sql.Date(startDate.getTime()));
pstmt1.setDate(3, new java.sql.Date(stopDate.getTime()));
rsBySP = pstmt1.executeQuery();
while (rsBySP.next()) {
ps = conn.prepareStatement(getSalesPersons);
ps.setInt(1, rsBySP.getInt(1));
rsSP = ps.executeQuery();
if (rsSP.next()) {
ps = conn.prepareStatement(getPrevTotalSalesBySP);
// Get previous year date
Calendar cal = Calendar.getInstance();
cal.setTime(startDate);
cal.add(Calendar.YEAR, -1);
prevStartDate = cal.getTime();
cal.setTime(stopDate);
cal.add(Calendar.YEAR, -1);
prevStopDate = cal.getTime();
ps.setString(1, rsBySP.getString(1));
ps.setDate(2,new java.sql.Date(prevStartDate.getTime()));
ps.setDate(3, new java.sql.Date(prevStopDate.getTime()));
rsBySPLY = ps.executeQuery();
if (rsBySPLY.next()) {
// Count Invoices for Last Year
ps = conn.prepareStatement(findCountBySP);
ps.setDate(1, new java.sql.Date(prevStartDate.getTime()));
ps.setDate(2, new java.sql.Date(prevStopDate.getTime()));
ps.setString(3, rsBySP.getString(1));
rsCountLY2 = ps.executeQuery();
if (rsCountLY2.next()) {
ps = conn.prepareStatement(findCountBySP);
ps.setDate(1, new java.sql.Date(startDate.getTime()));
ps.setDate(2, new java.sql.Date(stopDate.getTime()));
ps.setString(3, rsBySP.getString(1));
rsCount2 = ps.executeQuery();
if (rsCount2.next()) {
ps = conn.prepareStatement(trafficCountBySP);
ps.setDate(1, new java.sql.Date(startDate.getTime()));
ps.setDate(2, new java.sql.Date(stopDate.getTime()));
ps.setString(3, rsBySP.getString(1));
rsTCount2 = ps.executeQuery();
if (rsTCount2.next()) {
ps = conn.prepareStatement(trafficCountBySP);
ps.setDate(1, new java.sql.Date(prevStartDate.getTime()));
ps.setDate(2, new java.sql.Date(prevStopDate.getTime()));
ps.setString(3, rsBySP.getString(1));
rsTCountLY2 = ps.executeQuery();
if (rsTCountLY2.next()) {
TotalSalesInformationBySalesPerson tbsp = new TotalSalesInformationBySalesPerson(rsSP.getString(1), rs.getString(2), rs.getInt(1),rsCount2.getInt(1), rsBySP.getDouble(2),rsBySPLY.getDouble(2),rsCountLY2.getInt(1),
rsTCount2.getInt(1),rsTCountLY2.getInt(1));
salesPersonResultList.add(tbsp);
} else {
TotalSalesInformationBySalesPerson tbsp = new TotalSalesInformationBySalesPerson(
rsSP.getString(1), rs
.getString(2), rs
.getInt(1),
rsCount2.getInt(1), rsBySP
.getDouble(2),
rsBySPLY.getDouble(2),
rsCountLY2.getInt(1),
rsTCount2.getInt(1), 0);
salesPersonResultList.add(tbsp);
}
}
}
}
} else {
ps = conn.prepareStatement(findCountBySP);
ps.setDate(1,
new java.sql.Date(startDate.getTime()));
ps
.setDate(2, new java.sql.Date(stopDate
.getTime()));
ps.setString(3, rsBySP.getString(1));
rsCount2 = ps.executeQuery();
if (rsCount2.next()) {
ps = conn.prepareStatement(trafficCountBySP);
ps.setDate(1, new java.sql.Date(startDate
.getTime()));
ps.setDate(2, new java.sql.Date(stopDate
.getTime()));
ps.setString(3, rsBySP.getString(1));
rsTCount2 = ps.executeQuery();
if (rsTCount2.next()) {
TotalSalesInformationBySalesPerson tbsp = new TotalSalesInformationBySalesPerson(
rsSP.getString(1), rs.getString(2),
rs.getInt(1), rsCount2.getInt(1),
rsBySP.getDouble(2), 0.00, 0,
rsTCount2.getInt(1), 0);
salesPersonResultList.add(tbsp);
} else {
TotalSalesInformationBySalesPerson tbsp = new TotalSalesInformationBySalesPerson(
rsSP.getString(1), rs.getString(2),
rs.getInt(1), rsCount2.getInt(1),
rsBySP.getDouble(2), 0.00, 0,
rsTCount2.getInt(1), 0);
salesPersonResultList.add(tbsp);
}
}
}
}
}
最佳答案
看起来您正在代码中进行联接,即执行查询,并针对返回的每条记录,对其中一些数据执行查询。然后实际上嵌套更多这样的查询。
通常可以在数据库中完成更多的连接工作,但我认为如果不查看数据库模式并理解代码的含义,我们无法提供更多帮助。
我建议您只考虑问题的一个级别,并考虑它是否可以表示为单个查询,或者一些相关查询的 UNION。然后从那里构建。
顺便说一句,您拥有的 Java 可以重新组织和重构,以使其更容易理解,将子查询拉出到它们自己的函数中 - 但希望您不需要像这样的嵌套代码。
关于Java Struts 报告,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1784470/
我正在尝试从 struts-config 调用使用 struts 1 中的操作转发属性,并且我想调用另一个操作,它位于另一个 struts.config 文件中。显然它不起作用! 我的代码是: In
我是 Struts 框架的菜鸟。我试图了解 Action 映射是如何工作的。假设我有一个发送 AJAX 请求的 JavaScript 文件: $("button").click(function(){
嗨,我愿意更新从数据库中获取并加载到 JSP 上的复选框的值。我正在创建员工资料。 Jsp 具有员工姓名、员工地址、员工技术技能等字段。 员工技能具有以下复选框以选择以下值 复选框 1:Java 复选
在上面的代码中,fo
如何找到正在使用的 Struts 版本 在 Web应用项目在 Eclipse 中? 我的 struts-config.xml 说 谢谢。 最佳答案 打开 struts jar 并在 META-INF
我一段时间以来一直试图找到这个问题的明确答案,但没有任何运气。我需要知道为什么Struts是紧耦合的? struts 的哪个组件使其紧密耦合。 最佳答案 这太棒了Mkyong article正如我们所
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
我只是尝试在带有 struts 提供的标签的 jsp 页面中包含一个文本框。但它表现得很典型。 在职的 不工作 所以,没有属性(property)'value' ,它不工作。 请帮帮我。 笔记: 使
我使用 eclipse 来实现原生 Struts 和 hybernate 支持应用程序在页面中显示一系列链接。我收到错误: javax.servlet.jsp.JspException: Cannot
我的 JSP 中有以下代码: .. .. .. .. 这在 struts-config.xml 中文件: 喜欢delete行动吧,我有edit和up
谁能解释一下 Struts 和 Tapestry 框架之间的区别或者它们之间的比较? 问候,马亨德拉·阿特尼亚孟买印度 最佳答案 此处更新了 Tapestry 教程:http://tapestry.a
我有一个在 weblogic 上运行的 j2ee 应用程序。我对我的多功能盒感到困惑。 我对 multibox 的了解是,选中的项目将在提交时作为字符串数组传递。 我不知道为什么在我的应用程序中,当我
我正在设计一个购物车项目,其中只有我的内容区域会发生变化,因此我使用 struts 磁贴对其进行了配置,并且一切正常,直到我在我的项目中遇到表单。每当我尝试使用图 block 显示表单(struts
我想删除在 Struts 1.3 显示标签中没有找到显示的消息,当没有从数据库中获取记录时。 有可能这样做吗...? 最佳答案 从我的角度来看,默认行为应该是在空数据源的情况下不显示任何消息。 emp
我在浏览器窗口中收到以下错误: org.apache.jasper.JasperException:javax.servlet.ServletException:javax.servlet.jsp.J
我是 Struts 的新手。我在 struts 中有一个现有的 java 项目。该项目有 struts.xml 和 .struts.mex 文件。我了解到 struts.xml 是 Action 类到
我遇到了问题。我一直在不同的论坛上寻找答案,但不幸的是我没有找到答案。我需要这个,因为我正在创建一个网页,您可以在其中更改语言,因此不能对其进行硬编码。我需要这样做: "> 所以我想将 html 标记
我正在使用 Struts 2.1.8.1。我想在我的 jsp 页面中使用 struts 提供的标签。例如 Transfer Program - Log
我创建了一个名为 RegesterAction 的新类,但我没有将此类保留在任何包中。如何在 struts.xml 中配置此类? 下面是 struts.xml 文件,但我无法理解属性值 "defaul
我正在开发一个支持 AJAX 的 JavaScript 前端,它可以调用用 Struts 编写的 Java 后端。我的问题是,当后端抛出异常时,客户端仍然会看到“200 OK”HTTP 响应代码,而不
我是一名优秀的程序员,十分优秀!