设计器外挂菜单展现数据库中保存的报表
第36章 设计器外挂菜单展现数据库中保存的报表
1 . 问题概述
同设计器外挂菜单保存报表模板到数据库中
2 . 案例
浙江公众信息
3 .流程步骤
1. 在报表设计器中文件菜单(systemconfig.xml)中外挂菜单,可命名为:展示数据库中报表
2.选中从数据库选出报表菜单:
3.打开报表设计器选择展示数据库中报表,弹出界面可选择报表的编号及预览效果
4. 选择报表编号点击确定可以在设计器中打开对应得报表,修改之后可以再回填数据库
4. 解决思路
1. 编写Java类实现报表外挂菜单功能类
2. 在Java类中实现读取数据库中报表编号功能,同时实现通过报表编号读取数据库中报表的
功能
3. 调用报表接口展示报表
4. 配置外挂菜单到润乾报表设计器中
5. 程序说明
1.定义Swing界面,连接数据库,执行报表列表和报表的浏览, GetRecordsFromTable.java代码:
package api;
import java.io.ByteArrayInputStream;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.Map;
import javax.swing.JPanel;
import javax.swing.JDialog;
import javax.swing.JLabel;
import javax.swing.JScrollPane;
import javax.swing.JTree;
import com.runqian.report4.usermodel.CSReport;
import com.runqian.report4.usermodel.IReport;
import com.runqian.report4.util.ReportUtils;
import javax.swing.JButton;
public class GetRecordsFromTable extends JDialog {
private static final long serialVersionUID = 1L;
private JPanel jContentPane = null;
private JLabel jLabel_bblb = null;
private JScrollPane jScrollPane = null;
private JTree jTree = null;
private JLabel jLabel_bbyl = null;
private JScrollPane jScrollPane1 = null;
private JPanel jPanel = null;
private JButton jButton_gb = null;
private JButton jButton_qd = null;
private final static String driver = “com.newatlanta.jturbo.driver.Driver”;
private final static String url = “jdbc:JTurbo://localhost/exercise/charset=GBK”;
private final static String username = “sa”;
private final static String password = “sa”;
private Connection con = null;
private Map smap = new HashMap();
private InputStream is;
private String fileName = “”;
public int flag = 0;
public int getFlag() {
return flag;
}
public void setFlag(int flag) {
this.flag = flag;
}
public InputStream getIs() {
return is;
}
public void setIs(InputStream is) {
this.is = is;
}
public String getFileName() {
return fileName;
}
public void setFileName(String fileName) {
this.fileName = fileName;
}
/**
* This is the default constructor
*/
public GetRecordsFromTable() {
super();
initialize();
}
/**
* This method initializes this
*
* @return void
*/
private void initialize() {
con getConnection(driver, url, username, password);
this.setSize(870, 590);
this.setTitle(“选出报表“);
this.setContentPane(getJContentPane());
}
/**
* This method initializes jContentPane
*
* @return javax.swing.JPanel
*/
private JPanel getJContentPane() {
if (jContentPane == null) {
jLabel_bbyl = new JLabel();
jLabel_bbyl.setBounds(new java.awt.Rectangle(218, 15, 68, 18));
jLabel_bbyl.setText(“报表预览“);
jLabel_bblb = new JLabel();
jLabel_bblb.setBounds(new java.awt.Rectangle(21, 15, 70, 18));
jLabel_bblb.setText(“报表列表“);
jContentPane = new JPanel();
jContentPane.setLayout(null);
jContentPane.add(jLabel_bblb, null);
jContentPane.add(getJScrollPane(), null);
jContentPane.add(jLabel_bbyl, null);
jContentPane.add(getJScrollPane1(), null);
jContentPane.add(getJButton(), null);
jContentPane.add(getJButton1(), null);
}
return jContentPane;
}
/**
* This method initializes jScrollPane
*
* @return javax.swing.JScrollPane
*/
private JScrollPane getJScrollPane() {
if (jScrollPane == null) {
jScrollPane = new JScrollPane();
jScrollPane.setBounds(new java.awt.Rectangle(22, 35, 172, 440));
jScrollPane.setViewportView(getJTree());
}
return jScrollPane;
}
/**
* This method initializes jTree
*
* @return javax.swing.JTree
*/
private JTree getJTree() {
Statement smt = null;
ResultSet rs = null;
int rowNum = 0;
Hashtable h = new Hashtable();
try {
smt = con.createStatement();
rs = smt.executeQuery(“select count(*) as num from raq “);
while (rs.next()) {
rowNum = rs.getInt(“num”);
}
} catch (SQLException e) {
e.printStackTrace();
}
String[] s = new String[rowNum];
int i = 0;
try {
rs = smt.executeQuery(“select id,fileName from raq “);
while (rs.next()) {
s[i] = rs.getString(“fileName”);
smap.put(s[i], String.valueOf(rs.getInt(“id”)));
i++;
}
} catch (SQLException e) {
e.printStackTrace();
}
h.put(“raq”, s);
try {
if (smt != null) {
smt.close();
}
if (rs != null) {
rs.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
if (jTree == null) {
jTree = new JTree(h);
jTree.addMouseListener(new java.awt.event.MouseAdapter() {
public void mouseClicked(java.awt.event.MouseEvent e) {
if (e.getClickCount() == 2
&& !((JTree) e.getSource())
.getLastSelectedPathComponent().toString()
.equals(“raq”)) {
fileName = ((JTree) e.getSource())
.getLastSelectedPathComponent().toString();
Statement smt = null;
ResultSet rs = null;
IReport rd = null;
int id = 0;
InputStream isForView = null;
id = Integer.parseInt((String) smap.get(((JTree) e
.getSource()).getLastSelectedPathComponent()
.toString()));
try {
smt = con.createStatement();
rs = smt
.executeQuery(“select content from raq where id= “
+ id);
while (rs.next()) {
is = (InputStream) rs
.getBinaryStream(“content”);
isForView = (InputStream) rs
.getBinaryStream(“content”);
}
if (isForView != null) {
try {
rd = ReportUtils.read(isForView);
} catch (Exception e2) {
e2.printStackTrace();
}
}
CSReport cSReport = new CSReport(rd);
jScrollPane1.remove(jPanel);
JPanel jPanel = new JPanel();
try {
jPanel.add(cSReport.getDisplayPane());
} catch (Throwable e1) {
e1.printStackTrace();
}
jScrollPane1.setViewportView(jPanel);
try {
isForView.close();
} catch (IOException e1) {
e1.printStackTrace();
}
} catch (SQLException e1) {
e1.printStackTrace();
}
}
}
});
}
return jTree;
}
/**
* This method initializes jScrollPane1
*
* @return javax.swing.JScrollPane
*/
private JScrollPane getJScrollPane1() {
if (jScrollPane1 == null) {
jScrollPane1 = new JScrollPane();
jScrollPane1.setBounds(new java.awt.Rectangle(218, 34, 623, 439));
jScrollPane1.setViewportView(getJPanel());
}
return jScrollPane1;
}
/**
* This method initializes jPanel
*
* @return javax.swing.JPanel
*/
private JPanel getJPanel() {
if (jPanel == null) {
jPanel = new JPanel();
}
return jPanel;
}
/**
* This method initializes jButton
*
* @return javax.swing.JButton
*/
private JButton getJButton() {
if (jButton_gb == null) {
jButton_gb = new JButton();
jButton_gb.setBounds(new java.awt.Rectangle(231, 512, 89, 28));
jButton_gb.setText(“关闭“);
jButton_gb.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent e) {
flag = 1;
if (con != null) {
try {
con.close();
} catch (SQLException e1) {
e1.printStackTrace();
}
}
dispose();
}
});
}
return jButton_gb;
}
private static Connection getConnection(String driver, String url,
String username, String password) {
try {
Class.forName(driver);
} catch (ClassNotFoundException e) {
}
Connection con = null;
try {
con = DriverManager.getConnection(url, username, password);
} catch (SQLException e) {
e.printStackTrace();
}
return con;
}
/**
* This method initializes jButton1
*
* @return javax.swing.JButton
*/
private JButton getJButton1() {
if (jButton_qd == null) {
jButton_qd = new JButton();
jButton_qd.setBounds(new java.awt.Rectangle(486, 512, 89, 27));
jButton_qd.setText(“确定“);
jButton_qd.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent e) {
flag = 2;
if (con != null) {
try {
con.close();
} catch (SQLException e1) {
e1.printStackTrace();
}
}
dispose();
}
});
}
return jButton_qd;
}
}
2. 选择报表编号点击确定在设计器中打开对应得报表GetReportListFromDB.java代码:
package api;
import java.awt.event.ActionEvent;
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.util.HashMap;
import com.runqian.report4.ide.configmenu.CMAction;
import com.runqian.report4.usermodel.IReport;
import com.runqian.report4.util.ReportUtils;
public class GetReportListFromDB extends CMAction {
/**
* 要保存报表时从主程序获取当前编辑的报表对象
*
* @return IReport 要保存报表时从主程序获取当前编辑的报表对象
*/
public IReport getCurrentReportObj() {
try {
return (IReport) handler.processMessage(“HttpSave”, null);
} catch (Exception e) {
}
return null;
}
/**
* 打开报表
*
* @param reportStream
*报表流
* @param reportName
*报表名称
* @return boolean 成功打开报表返回true遭遇异常返回false
*/
public boolean openRemoteReport(InputStream reportStream, String reportName) {
try {
HashMap hm = new HashMap();
hm.put(“stream”, reportStream);
hm.put(“filename”, reportName);
handler.processMessage(“httpopen”, hm);
return true;
} catch (Exception e) {
}
return false;
}
/**
* 获取当前编辑的报表流
*
* @return InputStream 获取当前编辑的报表流
*/
private InputStream getCurrentReportStream() {
try {
return (InputStream) handler.processMessage(“getRaqInputStream”,
null);
} catch (Exception e) {
}
return null;
}
public void actionPerformed(ActionEvent arg0) {
InputStream is = getCurrentReportStream();
if (is != null) {
GetRecordsFromTable grdft = new GetRecordsFromTable();
grdft.setModal(true);
grdft. show ();
if (grdft.getFlag() == 2) {
openRemoteReport(grdft.getIs(), grdft.getFileName());
try {
grdft.getIs().close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}