Java GUI : iReport Create Parameters and Pass Variable |
Java GUI : iReport Create Parameters and Pass Variable บทความนี้เป็นสุดยอดเทคนิคการเขียน Java GUI กับ iReport วิธีหนึ่งที่น่าสนใจมาก เพราะหัวใจลองการออก Report ก็คือการให้ Report สามารถทำการ Query แสดง ข้อมูลให้ได้ตรงกับความต้องการ เช่น กรณีที่ต้องการ Report ของลูกค้าก็จะต้องมีการส่งรหัสของลุกค้าที่ต้องการไป Filter ข้อมูลใน iReport จากนั้น iReport จะนำรหัสนั้น ๆ ไปเลือกข้อมูลที่ต้องการมาแสดงผลในหน้า Report
Java GUI : iReport Create Parameters and Pass Variable
ซึ่งวิธีนี้เราจะต้องใช้การสร้าง Parameters ในฝั่งของ iReport จากนั้นใน Java GUI ก็จะทำการส่งค่า Parameters ให้กับ iReport เมื่อ iReport ได้ค่าเหล่านั้นก็จะนำไป Query ข้อมูลมาแสดงผล ซึ่งรูปแบบการส่ง Parameters มีดังนี้
// Connection
Class.forName("com.mysql.jdbc.Driver");
Connection connect = DriverManager.getConnection("jdbc:mysql://localhost/mydatabase" +
"?user=root&password=root");
// Parameters
Map param = new HashMap();
param.put("p1", "val");
param.put("p2", "val");
// Report Viewer
JasperReport ir = JasperCompileManager.compileReport(report);
JasperPrint ip = JasperFillManager.fillReport(ir, param,connect);
JasperViewer.viewReport(ip);
// Connection Close
connect.close();
Step 1 สร้าง Parameters ไว้รับค่า บน iReport
data:image/s3,"s3://crabby-images/402a8/402a8b2873f36e3ae54bb6e19bb1c231fa120829" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
กลับมายังหน้า Report บน iReport
data:image/s3,"s3://crabby-images/07079/070790e7c49d4a8ee4e0e0d3e3a5922110eb5e10" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
ในส่วนของ Report Inspector จะมี Parameters
data:image/s3,"s3://crabby-images/98418/984181a179c129f818ece1cab03072f8f919b68f" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
ให้คลิกขวาเลือก Add Parameters
data:image/s3,"s3://crabby-images/6ed01/6ed011ad9c28c466161f4f8c6cd9caa194ea8d48" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
ได้ Parametrs ชื่อว่า parameters 1
data:image/s3,"s3://crabby-images/c3db0/c3db0cc9dc67a9e2a9cc31d96370a000f1f54f0c" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
ใน parameters 1 จะมี Property
data:image/s3,"s3://crabby-images/22623/22623f578369514443785a0f1b42438bf4f41504" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
ให้เปลี่ยนชื่อเป็น sCoutryCode และเลือกชนิดเป็น String
data:image/s3,"s3://crabby-images/cfbb8/cfbb8ad4495874aeafbeb230c5f5c22e6a49529f" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
จากนั้นให้คลิกที่ Query รูป Icon กลืม ๆ ดังรูป
data:image/s3,"s3://crabby-images/7d0cf/7d0cfe5551c57d04ca33faf8a3e7ae02beed6bfb" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
ซึ่งตอนนี้จะเป็น Query คำสั่งของ SQL
data:image/s3,"s3://crabby-images/908e6/908e6099a5084f254b285d474333fa2bed6ccdae" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
ให้เขียน Query เพิ่ม โดยเราจะ WHERE ตาม CountryCode ของลูกค้า
WHERE CountryCode = $P{sCountryCode}
สามารถเขียน Query ต่าง ๆ ได้เหมือนกับการเขียน SQL กรณีที่มีมากกว่า 1 ตัวก็ให้ใช้ AND ได้ตามปกติ และเพียงเท่านี้ก็ถือว่าเป็นการเสร้จสิ้นขั้นตอนการสร้าง Parameters
data:image/s3,"s3://crabby-images/fb383/fb38346e31d9bb4f28f9550c882abb3d761cac7e" alt=""
Step 2 ทำการ Preview ทดสอบการทำงานของ Query
data:image/s3,"s3://crabby-images/42b97/42b97c4715fd9548e77801ee93fc270e7c0bd786" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
เลือก Preview
data:image/s3,"s3://crabby-images/cdd7b/cdd7bc54de1ee85e5b1bd07b756885129732e83d" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
จะเห็นว่าเมื่อ Preview ผ่าน iReport โปรแกรมจะมี Dialog เพื่อให้เราทำการ Input ตัว Parameters
data:image/s3,"s3://crabby-images/59464/594642e693c19be971d6907fa79cb46260c4da3e" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
ใส่รหัส CountryCode ที่ต้องการ
data:image/s3,"s3://crabby-images/a9f97/a9f97857cf6f548ce1ad76e41a65dea559f72a70" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
จากนั้นตัว Report ก็จะ Filter และ Query ข้อมูลเฉพาะตามที่เราเขียน Query ไว้
data:image/s3,"s3://crabby-images/a9f97/a9f97857cf6f548ce1ad76e41a65dea559f72a70" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
จาก Code จะเห็นว่าใน JasperPrint จะมี Argument ให้เราทำการ Assign ค่า Parameters ให้กับ iReport
Step 3 การ Preview และ Viewer ตัว iReport บน Java GUI
data:image/s3,"s3://crabby-images/fb6b5/fb6b5c372e3f160a56c6fc7211c3e70bffaaf98d" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
การโยนค่า Parameters ให้กับ iReport จาก Code ของ Java
Code ทั้งหมด
MyForm.java
package com.java.myapp;
import java.awt.EventQueue;
import javax.swing.JFrame;
import javax.swing.JButton;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
import java.io.File;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperCompileManager;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.JasperReport;
import net.sf.jasperreports.swing.JRViewer;
import net.sf.jasperreports.view.JasperViewer;
public class MyForm extends JFrame {
/**
* Launch the application.
*/
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
public void run() {
MyForm frame = new MyForm();
frame.setVisible(true);
}
});
}
/**
* Create the frame.
*/
public MyForm() {
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setBounds(100, 100, 431, 286);
setTitle("ThaiCreate.Com Java GUI Tutorial");
getContentPane().setLayout(null);
// Button Report
JButton btnOpenReport = new JButton("Open Report");
btnOpenReport.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent arg0) {
Connection connect = null;
try {
Class.forName("com.mysql.jdbc.Driver");
connect = DriverManager.getConnection("jdbc:mysql://localhost/mydatabase" +
"?user=root&password=root");
} catch (ClassNotFoundException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// Application path
String report = null;
try {
report = new File(".").getCanonicalPath()+ "\\myReport.jrxml";
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
try {
// Parameters
Map param = new HashMap();
param.put("sCountryCode", "US");
// Report Viewer
JasperReport ir = JasperCompileManager.compileReport(report);
JasperPrint ip = JasperFillManager.fillReport(ir, param,connect);
JFrame frame = new JFrame();
frame.setTitle("ThaiCreate.Com Customer Report");
frame.setBounds(100, 100, 800,600);
frame.getContentPane().add(new JRViewer(ip));
frame.setVisible(true);
} catch (JRException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
connect.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
});
btnOpenReport.setBounds(137, 98, 146, 23);
getContentPane().add(btnOpenReport);
setResizable (false);
}
}
Output
data:image/s3,"s3://crabby-images/f0d75/f0d75ab55e2498b36b1b1db241d85a45bfd6b7dd" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
คลิกที่ Button ของ Open Report
data:image/s3,"s3://crabby-images/b5d88/b5d88393765c5a289f032f6f9003eb3ea90cefc9" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
Map param = new HashMap();
param.put("sCountryCode", "US");
Report ก็จะแสดงตาม Parameters ที่เรากำหนดขึ้น โดยในตัวอย่างนี้จะให้ Query ตาม CountryCode ของลูกค้า
หรือจะออกแบบเป็น Text Fields เพื่อรับค่าจาก Input
data:image/s3,"s3://crabby-images/6f9af/6f9afeae6f86a8045e8830e26f80c2c1dd2afb3d" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
package com.java.myapp;
import java.awt.EventQueue;
import javax.swing.JFrame;
import javax.swing.JButton;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
import java.io.File;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperCompileManager;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.JasperReport;
import net.sf.jasperreports.swing.JRViewer;
import net.sf.jasperreports.view.JasperViewer;
import javax.swing.JLabel;
import javax.swing.SwingConstants;
import javax.swing.JTextField;
public class MyForm extends JFrame {
private JTextField txtCountryCode;
/**
* Launch the application.
*/
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
public void run() {
MyForm frame = new MyForm();
frame.setVisible(true);
}
});
}
/**
* Create the frame.
*/
public MyForm() {
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setBounds(100, 100, 431, 286);
setTitle("ThaiCreate.Com Java GUI Tutorial");
getContentPane().setLayout(null);
// Label Country Code
JLabel lblCountryCode = new JLabel("Country Code");
lblCountryCode.setHorizontalAlignment(SwingConstants.CENTER);
lblCountryCode.setBounds(123, 31, 160, 14);
getContentPane().add(lblCountryCode);
// Text Field CountryCode
txtCountryCode = new JTextField();
txtCountryCode.setHorizontalAlignment(SwingConstants.CENTER);
txtCountryCode.setBounds(161, 56, 86, 20);
getContentPane().add(txtCountryCode);
txtCountryCode.setColumns(10);
setResizable (false);
// Button Report
JButton btnOpenReport = new JButton("Open Report");
btnOpenReport.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent arg0) {
Connection connect = null;
try {
Class.forName("com.mysql.jdbc.Driver");
connect = DriverManager.getConnection("jdbc:mysql://localhost/mydatabase" +
"?user=root&password=root");
} catch (ClassNotFoundException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// Application path
String report = null;
try {
report = new File(".").getCanonicalPath()+ "\\myReport.jrxml";
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
try {
// Parameters
Map param = new HashMap();
param.put("sCountryCode", txtCountryCode.getText());
// Report Viewer
JasperReport ir = JasperCompileManager.compileReport(report);
JasperPrint ip = JasperFillManager.fillReport(ir, param,connect);
JFrame frame = new JFrame();
frame.setTitle("ThaiCreate.Com Customer Report");
frame.setBounds(100, 100, 800,600);
frame.getContentPane().add(new JRViewer(ip));
frame.setVisible(true);
} catch (JRException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
connect.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
});
btnOpenReport.setBounds(137, 98, 146, 23);
getContentPane().add(btnOpenReport);
}
}
Output
data:image/s3,"s3://crabby-images/6f9af/6f9afeae6f86a8045e8830e26f80c2c1dd2afb3d" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
แสดง Input กรอกรหัส CountryCode
data:image/s3,"s3://crabby-images/4c0f2/4c0f22010e4d240b4564eb2df35f62972703eabf" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
แสดง Report ตามเงื่อนไขที่เรากำหนดขึ้น
data:image/s3,"s3://crabby-images/cc7e3/cc7e3477d1e64e7fb86aaa3737a6b49232648923" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
ทดสอบเปลี่ยนเป็น TH
data:image/s3,"s3://crabby-images/fc0a6/fc0a6dccade81dc5b8b9cee000ce253219d6fdeb" alt="iReport Create Parameters and Pass Variable iReport Create Parameters and Pass Variable"
แสดง Report ตามเงื่อนไขที่ส่งจาก Parameters
Property & Method (Others Related) |
|
ช่วยกันสนับสนุนรักษาเว็บไซต์ความรู้แห่งนี้ไว้ด้วยการสนับสนุน Source Code 2.0 ของทีมงานไทยครีเอท
|
|
|
By : |
ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ) |
|
Score Rating : |
data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" |
|
|
Create/Update Date : |
2013-09-12 11:43:20 /
2017-03-27 21:36:44 |
|
Download : |
No files |
|
Sponsored Links / Related |
|
|
|
|
|
|
|