使用Unicentapos中的所有数据库表生成事务报告

时间:2017-02-10 16:31:12

标签: mysql sql-server

我正在尝试在中生成报告。该报告是在Jasper中创建的,但是有一个相应的bs文件。只有一个SQL查询,对于我的报告,我需要在jrxml文件中进行多次查询。

这是sales_extendedcashregisterlog.bs文件,只有一个SQL查询report.setSentence()

report = new com.openbravo.pos.reports.PanelReportBean();

report.setTitleKey("Menu.ExtendedCashRegisterLog");
report.setReport("/com/openbravo/reports/sales_extendedcashregisterlog");
report.setResourceBundle("com/openbravo/reports   /sales_extendedcashregisterlog_messages");

 report.setSentence("SELECT " +
    "tickets.TICKETID AS TICKET_NO, " +
    "receipts.DATENEW AS TICKET_DATE, " +
    "people.NAME AS PERSON, " +
    "payments.PAYMENT AS PAYMENT, " +
    "payments.NOTES, " +
    "payments.TOTAL AS MONEY, " +
    "payments.TENDERED " +
"FROM ((tickets tickets " +
    "LEFT OUTER JOIN people people ON (tickets.PERSON = people.ID)) " +
    "RIGHT OUTER JOIN receipts receipts ON (receipts.ID = tickets.ID)) " +
    "LEFT OUTER JOIN payments payments ON (receipts.ID = payments.RECEIPT) " +
"WHERE ?(QBF_FILTER) " +
    "ORDER BY TICKET_DATE ASC");

     report.addParameter("receipts.DATENEW");
     report.addParameter("receipts.DATENEW");

      paramdates = new com.openbravo.pos.reports.JParamsDatesInterval();

     paramdates.setStartDate(com.openbravo.beans.DateUtils.getToday());
     // JG - 8 Jan 14        paramdates.setEndDate(com.openbravo.beans.DateUtils.getToday());
    paramdates.setEndDate(com.openbravo.beans.DateUtils.getTodayMinutes());

      report.addQBFFilter(paramdates);

     report.addField("TICKET_NO", com.openbravo.data.loader.Datas.STRING);
      report.addField("TICKET_DATE", com.openbravo.data.loader.Datas.TIMESTAMP);
      report.addField("PERSON", com.openbravo.data.loader.Datas.STRING);
      report.addField("PAYMENT", com.openbravo.data.loader.Datas.STRING);
      report.addField("NOTES", com.openbravo.data.loader.Datas.STRING);
      report.addField("MONEY", com.openbravo.data.loader.Datas.DOUBLE);
       report.addField("TENDERED", com.openbravo.data.loader.Datas.DOUBLE);
      return report;

现在我们有一个jrxml文件。我可以使用托盘功能编辑此文件,但事情是sql查询,它给我字段,以便我可以使用它们。这是它已经拥有的jrxml文件的查询。

queryString>
    <![CDATA[SELECT 
 tickets.TICKETID AS TICKET_NO,
 receipts.DATENEW AS TICKET_DATE,
 payments.TOTAL AS MONEY,
 people.NAME AS PERSON,
 payments.PAYMENT AS PAYMENT
 FROM receipts
 LEFT JOIN tickets ON receipts.ID = tickets.ID
 LEFT JOIN payments ON receipts.ID = payments.RECEIPT
 LEFT JOIN people ON tickets.PERSON = PERSON.ID
 ORDER BY tickets.TICKETID]]>
 </queryString>
 <field name="TICKET_NO" class="java.lang.String"/>
 <field name="TICKET_DATE" class="java.util.Date"/>
 <field name="PERSON" class="java.lang.String"/>
 <field name="PAYMENT" class="java.lang.String"/>
 <field name="NOTES" class="java.lang.String"/>
<field name="MONEY" class="java.lang.Double"/>
<field name="TENDERED" class="java.lang.Double"/>

这些字段已在里面。现在我想添加多个sql查询,所以我究竟能做到这一点。

基本上我正在尝试使用所有需要的数据在unicentaopos中生成事务日志。

0 个答案:

没有答案