如何Jaspersoft iReport Designer绑定表格数据
3个回答
2017-03-02
展开全部
双击打开Jaspersoft iReport Designer,并打开最近创建的report,
通过“窗口”找到组件面板,将面板上的“Static Text”组件拖曳到设计器窗口,放在Column Header中,修改组件内显示的内容,作为报表表头,
接着,将组件面板上的“Text Field”拖到设计面板Detail 1上,并修改成SQL语句查询的字段名称,
然后,按照步骤2的操作步骤,将“Static Text”拖到Designer中的Page Header中,并修改其中显示的内容,
同理,将步骤4中的组件拖一个到Title中,修改显示的内容,
选中Title区域中的“Static Text”组件,找到右侧的属性设置面板,修改字体大小以及其他的样式,
修改完报表内容和展示的字段,设置好报表样式后,准备预览报表,点击上方的“Preview",填写好数据库密码。有时候真心就得ireport的售后做的也就是差强人意,我之前用的也是ireport后来公司换成了finereport报表软件,先是有专门的人员培训,网站上也有视频教程之类的,反正上课的时候好好听,自己后来做的时候基本上没什么问题。
通过“窗口”找到组件面板,将面板上的“Static Text”组件拖曳到设计器窗口,放在Column Header中,修改组件内显示的内容,作为报表表头,
接着,将组件面板上的“Text Field”拖到设计面板Detail 1上,并修改成SQL语句查询的字段名称,
然后,按照步骤2的操作步骤,将“Static Text”拖到Designer中的Page Header中,并修改其中显示的内容,
同理,将步骤4中的组件拖一个到Title中,修改显示的内容,
选中Title区域中的“Static Text”组件,找到右侧的属性设置面板,修改字体大小以及其他的样式,
修改完报表内容和展示的字段,设置好报表样式后,准备预览报表,点击上方的“Preview",填写好数据库密码。有时候真心就得ireport的售后做的也就是差强人意,我之前用的也是ireport后来公司换成了finereport报表软件,先是有专门的人员培训,网站上也有视频教程之类的,反正上课的时候好好听,自己后来做的时候基本上没什么问题。
2017-02-27
展开全部
1)用ireport创建完成jrxml文件后,到ireport的安装目录找到相应的jasper文件,然后放到项目的一个目录中。(由于让程序每次都编译jrxml很浪费时间,再说模板也不容易改变,建议只编译一次就OK)
2)使用代码如下
Session session = HibernateUtil.currentSession();
Connection con = session.connection(); //得到链接
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQ ry("select * from applications_list where app_id='" +appId+"'"); //用数据集传入带参数的SQL语句
System.out.println("select * from applications_list where appl_list_id='" +appId+"'");
String appPath = req st.getSession().getServletContext().getRealPath("/"); //得到以便于好的jasper文件
if (appPath.lastIndexOf("\\") != appPath.length() - 1)appPath += "\\";
String reportFileName = appPath+ "jasper\\untitled_report_1.jasper";
Map parameters = new HashMap();
parameters.put("Title", "设备申请列表");//注意可以有很多个参数
JasperPrint jasperPrint = JasperFillManager.fillReport(reportFileName, parameters, new JRResultSetDataSource(rs));
JRRtfExporter exporter = null;
exporter = new JRRtfExporter();
response.setContentType("text/html; charset=UTF-8");
response.setContentType("application/msword");
String applicatiosname = ToUTF8.toUtf8String("设备申请单"); //处理下载后文件名中文问题
response.setHeader("Content-disposition","attachment;filename="+applicatiosname+".doc");
exporter.setParameter(JRExporterParameter.CHARACTER_ENCODING, "UTF-8");
exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, response.getOutputStream());
exporter.exportReport();
?
?
?
* 返回字符编码UTF-8 */
?p lic static String toUtf8String(String s) {
StringB?r sb = new StringB?r();
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
if (c >= 0 && c <= 255) {
sb.append(c);
} else {
byte[] b;
try {
b = Character.toString(c).getBytes("UTF-8");
} catch (Exception ex) {
//System.out.println(ex);
b = new byte[0];
}
for (int j = 0; j < b.length; j++) {
int k = b[j];
if (k < 0)
k += 256;
sb.append("%" + Integer.toHexString(k).toUpperCase());
}
}
}
return sb.toString();
?}
不懂楼主为什么要用这个也太麻烦了吧,上面是我去论坛里面搜的,真心无力啊啊,我用的finereport,功能很强大齐全啊,也不用还搞代码。网上有免费版,楼主可以百度看看,希望可以帮到你。
2)使用代码如下
Session session = HibernateUtil.currentSession();
Connection con = session.connection(); //得到链接
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQ ry("select * from applications_list where app_id='" +appId+"'"); //用数据集传入带参数的SQL语句
System.out.println("select * from applications_list where appl_list_id='" +appId+"'");
String appPath = req st.getSession().getServletContext().getRealPath("/"); //得到以便于好的jasper文件
if (appPath.lastIndexOf("\\") != appPath.length() - 1)appPath += "\\";
String reportFileName = appPath+ "jasper\\untitled_report_1.jasper";
Map parameters = new HashMap();
parameters.put("Title", "设备申请列表");//注意可以有很多个参数
JasperPrint jasperPrint = JasperFillManager.fillReport(reportFileName, parameters, new JRResultSetDataSource(rs));
JRRtfExporter exporter = null;
exporter = new JRRtfExporter();
response.setContentType("text/html; charset=UTF-8");
response.setContentType("application/msword");
String applicatiosname = ToUTF8.toUtf8String("设备申请单"); //处理下载后文件名中文问题
response.setHeader("Content-disposition","attachment;filename="+applicatiosname+".doc");
exporter.setParameter(JRExporterParameter.CHARACTER_ENCODING, "UTF-8");
exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, response.getOutputStream());
exporter.exportReport();
?
?
?
* 返回字符编码UTF-8 */
?p lic static String toUtf8String(String s) {
StringB?r sb = new StringB?r();
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
if (c >= 0 && c <= 255) {
sb.append(c);
} else {
byte[] b;
try {
b = Character.toString(c).getBytes("UTF-8");
} catch (Exception ex) {
//System.out.println(ex);
b = new byte[0];
}
for (int j = 0; j < b.length; j++) {
int k = b[j];
if (k < 0)
k += 256;
sb.append("%" + Integer.toHexString(k).toUpperCase());
}
}
}
return sb.toString();
?}
不懂楼主为什么要用这个也太麻烦了吧,上面是我去论坛里面搜的,真心无力啊啊,我用的finereport,功能很强大齐全啊,也不用还搞代码。网上有免费版,楼主可以百度看看,希望可以帮到你。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
直接用皕杰报表多好,简单易用,无需复杂的数据绑定
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询