JasperReports+iReport在eclipse中的使用

一、介绍

1)它可以PDF,HTML,XML等多种形式产生报表或动态报表,在新版本还支持CSV,XLS,RTF等格式的报表;
2)它按预定义的XML文档来组织数据,来源多(如:关系数据库,Java容器对象(collection,arrays)等);
报表的填充过程:
先产生报表设计对象->序列化该对象->存储在磁盘或网络->产生XML文件(表格数据)。
表单的设计过程就是用定义于XML文件中的Java表达式来实现报表的设计。
3)它带数据一致性验证;
4)报表引擎必须先接受数据(通过参数等多种形式)来产生报表,更多的是来自数据源,引擎直接接收用于填充表格的数据源对象,或者通过自身提供的JDBC连接对象来处理数据库的数据;
5)报表最终要产生一个新的对象来进行填充操作,从而产生打印文档对象,这也是存储在磁盘或网络传输介质的序列化对象;
6)内置浏览器能直接查看结果,以PDF,HTML,XML导出;
7)重要的类:
net.sf.jasperreports.engine.design.JasperDesign
其实例是用于报表产生的原始类;
net.sf.jasperreports.engine.design.JasperReport
表现了报表设计对象,是作为报表的编译过程的结果而被实例化,是向报表中填充数据的准备。

二、结构

JasperReports用XML文件来定义,约定用jrxml作为文件的后缀名。

1)主要元素:

 根元素
<span style="color: #000000;"> 报表的标题
</span><pageHeader><span style="color: #000000;"> 页眉
</span><detail><span style="color: #000000;"> 正文
</span><pageFooter><span style="color: #000000;"> 页脚
</span><band> 定义报表部件,以上所有元素都包含一个band元素作为其唯一子元素。</span></pre> 
  </div> 
  <p style="margin-left: 30px; text-align: left;"><span style="font-family: 仿宋; font-size: 15px;">除了根元素,其余元素是可选的。</span></p> 
  <p style="margin-left: 30px; text-align: left;"><span style="font-family: 仿宋; font-size: 15px;">2)其编辑工具iReport在Eclipse3.2下的安装过程</span></p> 
  <p style="margin-left: 30px; text-align: left;"><span style="font-family: 仿宋; font-size: 15px;">菜单“帮助”->“软件更新”->“查找并安装”->“搜索要安装的新功能部件”--(下一步)-->“新建远程站点”,输入以下内容:<br>名称:JasperForge<br>URL:http://www.jasperforge.org/update<br>--(确定)-->“下一步”-->直至完成。</span></p> 
  <p style="margin-left: 30px; text-align: left;"><span style="font-family: 仿宋; font-size: 15px;">3)以JasperReports1.3.0版本为例,一个JasperReports项目需要如下jar包:</span></p> 
  <table style="height: 200px; width: 664px; margin-left: 30px;" border="0"> 
   <tbody> 
    <tr> 
     <td style="margin-left: 60px;"><span style="font-family: 仿宋; font-size: 14px;">包名</span></td> 
     <td><span style="font-family: 仿宋; font-size: 14px;">说明</span></td> 
    </tr> 
    <tr> 
     <td><span style="font-family: 仿宋; font-size: 14px;">xml-apis.jar</span></td> 
     <td><span style="font-family: 仿宋; font-size: 14px;">XML parser API</span></td> 
    </tr> 
    <tr> 
     <td><span style="font-family: 仿宋; font-size: 14px;">jasperreports-1.3.0.jar</span></td> 
     <td><span style="font-family: 仿宋; font-size: 14px;">JasperReports API</span></td> 
    </tr> 
    <tr> 
     <td><span style="font-family: 仿宋; font-size: 14px;">commons-beanutils-1.7.jar </span></td> 
     <td><span style="font-family: 仿宋; font-size: 14px;"> JavaBeans Utility classes</span></td> 
    </tr> 
    <tr> 
     <td><span style="font-family: 仿宋; font-size: 14px;">commons-collections-2.1.jar</span></td> 
     <td><span style="font-family: 仿宋; font-size: 14px;">Collections framework extension classes</span></td> 
    </tr> 
    <tr> 
     <td><span style="font-family: 仿宋; font-size: 14px;">commons-digester-1.7.jar </span></td> 
     <td><span style="font-family: 仿宋; font-size: 14px;">classes for processing XML documents</span></td> 
    </tr> 
    <tr> 
     <td><span style="font-family: 仿宋; font-size: 14px;">commons-logging-1.0.2.jar </span></td> 
     <td><span style="font-family: 仿宋; font-size: 14px;">Logging classes</span></td> 
    </tr> 
    <tr> 
     <td><span style="font-family: 仿宋; font-size: 14px;">poi-2.0-final-20040126.jar </span></td> 
     <td><span style="font-family: 仿宋; font-size: 14px;"> Jarkarta POI API to generate an Excel Document</span></td> 
    </tr> 
    <tr> 
     <td><span style="font-family: 仿宋; font-size: 14px;">itext-1.3.1.jar  </span></td> 
     <td><span style="font-family: 仿宋; font-size: 14px;">PDF library</span></td> 
    </tr> 
   </tbody> 
  </table> 
  <h1><span style="font-family: 仿宋; font-size: 15px;">三、iReport介绍</span></h1> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">1)iReport是为JasperReports设计的强大的,直观的,易于使用的可视化报表设计器,为win32平台编写。允许用户可视化地编辑XML JasperDesign文件,可以和其它数据库进行JDBC通信。</span><br><span style="font-family: 仿宋; font-size: 15px;">再设计模板时可以以HTML,PDF,XML方式预览,用它生成的文件有.jrxml和.jasper两种文件。</span><br><span style="font-family: 仿宋; font-size: 15px;">.jrxml:是可视化编辑的xml文件;</span><br><span style="font-family: 仿宋; font-size: 15px;">.jasper:经编译后生成的类文件,即报表模板文件。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">2)iReport的输出格式</span><br><span style="font-family: 仿宋; font-size: 15px;">其预览输出格式有:PDF,HTML,CSV。JAVA2D,EXCEL,纯文本,JRView。</span><br><span style="font-family: 仿宋; font-size: 15px;">注意:JRViewer是直接以C/S方式作为报表的输出格式,在JFrame框架下输出。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">3)报表的动态对象变量、参数、字段</span><br><span style="font-family: 仿宋; font-size: 15px;">字段Fields:是从数据库抽取出来的,在报表中出现的数据库内容。$F</span><br><span style="font-family: 仿宋; font-size: 15px;">参数Parameters:你写的应用需要提供给报表的入口。 $P</span><br><span style="font-family: 仿宋; font-size: 15px;">变量Variables:报表中一些逻辑运算的表现。 $V</span><br><span style="font-family: 仿宋; font-size: 15px;">每个对象的定义格式如下: $V{variablesName}</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">4)运行时需要.jasper文件;编译:把.jrxml->.jasper文件。</span><br><span style="font-family: 仿宋; font-size: 15px;">静态运行:静态文本来运行,和数据源无关;</span><br><span style="font-family: 仿宋; font-size: 15px;">动态运行:带数据源运行。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">5)报表的结构</span><br><span style="font-family: 仿宋; font-size: 15px;">title、pageHeader、columnHeader、detail、columnFooter、pageFooter、summary、groupHeader、groupfooter。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">6)在iReport中创建数据库连接</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)菜单DourceSource -> Connections/DataSources -> ...new -></span><br><span style="font-family: 仿宋; font-size: 15px;">(2)菜单Build -> Set active connection -> 选择 -> ... -> OK</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">7)在iReport中创建文件</span><br><span style="font-family: 仿宋; font-size: 15px;">iReport工具是一个可视编辑器帮助创建JasperReports文件。JasperReports是一个基于Java报表的引擎。</span><br><span style="font-family: 仿宋; font-size: 15px;">当你在iReport中创建一个报表,你实际上是对配置文件进行操作,告诉JasperReports应该怎样建立Report。</span><br><span style="font-family: 仿宋; font-size: 15px;">三种文件:</span><br><span style="font-family: 仿宋; font-size: 15px;">.jasper文件:编译的二进制文件;</span><br><span style="font-family: 仿宋; font-size: 15px;">.jrxml文件:报表的配置文件;</span><br><span style="font-family: 仿宋; font-size: 15px;">.pdf文件:生成的pdf文件。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">8)报表格式化</span><br><span style="font-family: 仿宋; font-size: 15px;">在iReport上选择报表的一个区域,将呈现蓝色高亮显示;</span><br><span style="font-family: 仿宋; font-size: 15px;">可用鼠标拖曳来改变区域的尺寸,当误操作时,用undo来恢复;</span><br><span style="font-family: 仿宋; font-size: 15px;">如选择框变红,则有错误,report将不能编译;</span><br><span style="font-family: 仿宋; font-size: 15px;">改变字体或调整尺寸,菜单“View”->“Element properties”->分三个选择:</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)Common选择:尺寸,前景色/背景色,透明度,打印条件,位置属性等;</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)Font选择:字体、大小、类型,PDF字体,加粗,斜体,下划线,水平位置,垂直位置,PDF编码。</span><br><span style="font-family: 仿宋; font-size: 15px;">注意:两种字体:</span><br><span style="font-family: 仿宋; font-size: 15px;">     Font Name:将显示在iReport设计器和JasperReports运行中;</span><br><span style="font-family: 仿宋; font-size: 15px;">     PDF font Name:将显示在编译后的PDF文件中。</span><br><span style="font-family: 仿宋; font-size: 15px;">(3)Static Text:静态文本。</span><br><span style="font-family: 仿宋; font-size: 15px;">想浏览元素时,看“View”->“Elements browser”;</span><br><span style="font-family: 仿宋; font-size: 15px;">一次选择多个域,按“shift”键再用鼠标点击;</span><br><span style="font-family: 仿宋; font-size: 15px;">菜单“View”->“Report Properties”报表属性:</span><br><span style="font-family: 仿宋; font-size: 15px;">报表尺寸,单位,页边距,报表名,纵向Portrait/横向Landscape,列宽,Spacing,标题作为新页,Summary作为新页,XML编码(UTF-8)。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">9)使用Groups</span><br><span style="font-family: 仿宋; font-size: 15px;">菜单“View”->“Report query” 可以查询和修改SQL语句。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">10)为report增加参数</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)菜单“View”->“Report Query”,修改SQL语句,如:加上 WHERE LAST_NAME=$P{LAST_NAME}</span><br><span style="font-family: 仿宋; font-size: 15px;">注意:参数用$P{}来封装。</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)定义参数</span><br><span style="font-family: 仿宋; font-size: 15px;">菜单“View”->“Reports Parameters”</span><br><span style="font-family: 仿宋; font-size: 15px;">新建参数,如参数名为“LAST_NAME”,再指定参数的类型(如:String)</span><br><span style="font-family: 仿宋; font-size: 15px;">还可设定“缺省值”和参数的“描述”</span><br><span style="font-family: 仿宋; font-size: 15px;">运行报表(缺省),还可以传递参数方式:http://server/showReport?LAST_NAME=smith</span><br><span style="font-family: 仿宋; font-size: 15px;">菜单“Build”->“Execute report(using active conn.)”</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">11)创建子报表</span><br><span style="font-family: 仿宋; font-size: 15px;">例子:一个报表包含另一个报表</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)建立两个报表;</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)扩展master报表,增加一个subreport元素;</span><br><span style="font-family: 仿宋; font-size: 15px;">(3)双击subreport元素,设置其属性。在Subreport(other)栏中,</span><br><span style="font-family: 仿宋; font-size: 15px;">Subreport Expression填入“c:\test2.jasper”(第二个表即子表的文件名),点击“Add”,增加/修改:“Subreport parameter name”和Default value expression值;(COUNTRY     $F{COUNTRY})</span><br><span style="font-family: 仿宋; font-size: 15px;">(4)对子表“Report query”->添加''where COUNTRY=${COUNTRY}''</span><br><span style="font-family: 仿宋; font-size: 15px;">(5)增加“Report parameters”,(COUNTRY,java.lang.String)</span><br><span style="font-family: 仿宋; font-size: 15px;">(6)编译detail report;</span><br><span style="font-family: 仿宋; font-size: 15px;">(7)运行master report。</span></p> 
  <h1 style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">iReport支持Groovy脚本语言,可无需懂Java。</span></h1> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">1、配置XML文件</span><br><span style="font-family: 仿宋; font-size: 15px;">jasperreports的XML配置文件局域jasperreport.dtd文件而来。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">1)根元素jasperReport</span><br><span style="font-family: 仿宋; font-size: 15px;">其子元素有:报告的字体reportFont,参数parameter,查询字符串queryString,字段field,变量variable,组group,标题title,页眉pageHeader,列眉columnHeader,表明细detail,列脚columnFooter,页脚pageFooter。</span><br><span style="font-family: 仿宋; font-size: 15px;">属性有:列宽columnWidth,列间距columnSpacing,左边距leftMargin,顶边距topMargin,底边距bottomMargin。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">2)报表层字体含义reportFonts</span><br><span style="font-family: 仿宋; font-size: 15px;">无子元素;</span><br><span style="font-family: 仿宋; font-size: 15px;">属性有:名字name,是否缺省isFault,字体名fontName,字体大小size,是否粗体isBold,是否斜体isItalic,是否带下划线isUnderline,isStrikeThrough,PDF字体名pdfFontName,PDF编码pdfEncoding,是否嵌入PDF(isPdfEmbedded)。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">3)用于产生报表的对象参数parameter。引用P${name}</span><br><span style="font-family: 仿宋; font-size: 15px;">其子元素有:ParameterDescription,defaultValueExpression</span><br><span style="font-family: 仿宋; font-size: 15px;">属性有:name,class</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">4)从数据库检索数据的查询SQL语句 queryString</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">5)包含于report中的数据库表列字段 field。 引用F${name}</span><br><span style="font-family: 仿宋; font-size: 15px;">其子元素有:variableExpression,initialValueExpression</span><br><span style="font-family: 仿宋; font-size: 15px;">属性有:name,class</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">6)用在XML文件中的变量 Variable   引用V${name}</span><br><span style="font-family: 仿宋; font-size: 15px;">其子元素有:variableExpression,initialValueExpression</span><br><span style="font-family: 仿宋; font-size: 15px;">属性有:name,class</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">7)报表标题 title</span><br><span style="font-family: 仿宋; font-size: 15px;">其子元素有:band</span><br><span style="font-family: 仿宋; font-size: 15px;">无属性</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">8)页眉 pageHeader</span><br><span style="font-family: 仿宋; font-size: 15px;">其子元素有:band</span><br><span style="font-family: 仿宋; font-size: 15px;">无属性</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">9)报表的列名 columnHeader</span><br><span style="font-family: 仿宋; font-size: 15px;">其子元素有:band</span><br><span style="font-family: 仿宋; font-size: 15px;">无属性</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">10)指定的列值detail</span><br><span style="font-family: 仿宋; font-size: 15px;">其子元素有:band</span><br><span style="font-family: 仿宋; font-size: 15px;">无属性</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">11)列尾columnFooter</span><br><span style="font-family: 仿宋; font-size: 15px;">其子元素有:band</span><br><span style="font-family: 仿宋; font-size: 15px;">无属性</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">12)页脚pageFooter</span><br><span style="font-family: 仿宋; font-size: 15px;">其子元素有:band</span><br><span style="font-family: 仿宋; font-size: 15px;">无属性</span><br><span style="font-family: 仿宋; font-size: 15px;">注:在report中,一个band表示一个report节点。一个band元素包括:staticText(静态文本)和textElement(文本元素)两个元素。</span><br><span style="font-family: 仿宋; font-size: 15px;">常见报表模型:列表、分组、主从、嵌套、交叉、图形、套打、分栏、填报。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">2、创建报表</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">1)建立输入源</span><br><span style="font-family: 仿宋; font-size: 15px;">InputStream input = new FileInputStream(new File("c:\\JasperReports\\catalog.xml"));</span><br><span style="font-family: 仿宋; font-size: 15px;">JasperDesign design=JRXmlLoader.load(Input);</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">2)创建对象</span><br><span style="font-family: 仿宋; font-size: 15px;">JasperReport report = JasperCompileManager.compileReport(design);</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">3)获得JDBC连接从数据库检索数据</span><br><span style="font-family: 仿宋; font-size: 15px;">InitialContext initialContext = new InitialContext();</span><br><span style="font-family: 仿宋; font-size: 15px;">DataSource ds = (DataSource)initialContext.lookup("java:comp/env/jdbc/OracleDBConnectionDS");</span><br><span style="font-family: 仿宋; font-size: 15px;">Connection conn = ds.getConnection();</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">4)产生可预览、打印、输出为其它格式的JasperPrint文件</span><br><span style="font-family: 仿宋; font-size: 15px;">JasperPrint print = JasperFillManager.fillReport(report, parameters, conn);</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">5)参数处理</span><br><span style="font-family: 仿宋; font-size: 15px;">Map parameters = new HashMap();</span><br><span style="font-family: 仿宋; font-size: 15px;">parameters.put("ReportTitle", "PDF JasperReport");</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">6)输出成XML,PDF,HTML,CSV,XLS(Excel)的任一种文件。</span><br><span style="font-family: 仿宋; font-size: 15px;">OutputStream output = new FileOutputStream(new File("c:/JasperReports/catalog.pdf"))</span><br><span style="font-family: 仿宋; font-size: 15px;">JasperExportManager.exportReportToPdfStream(print,output);</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">3、JasperReports的安装配置</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">1)JDK的安装,注意JAVA_HOME环境变量;</span><br><span style="font-family: 仿宋; font-size: 15px;">2)要支持中文,需itext-1.3.1.jar和iTextAsian.jar包,加入CLASSPATH环境变量中;</span><br><span style="font-family: 仿宋; font-size: 15px;">3)安装iReport,用iReport-1.3.0-windows-installer.exe安装;</span><br><span style="font-family: 仿宋; font-size: 15px;">4)JasperReport不需任何配置,将其jar包(jasperreports-1.3.0.jar)放入CLASSPATH;</span><br><span style="font-family: 仿宋; font-size: 15px;">5)数据库的JDBC驱动包,例如Sybase的驱动包为jconn6.jar,加入到CLASSPATH。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">4、iReport的安装配置</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">iReport如果不用其安装文件iReport-1.3.0-windows-installer.exe安装,则需要配置。</span><br><span style="font-family: 仿宋; font-size: 15px;">iReport需Sun公司的JDK下的tools.jar,需拷贝到iReport的lib目录下。</span><br><span style="font-family: 仿宋; font-size: 15px;">iReport初始化配置的组成:</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)建立报表;</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)选择语言;</span><br><span style="font-family: 仿宋; font-size: 15px;">(3)加入到CLASSPATH。</span></p> 
  <h1 style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">四、Report Structure 报告的结构</span></h1> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">本章描述报告的结构,可用的report对象和它们的属性。这基本上是JasperReports的快速参考。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">1、Expressions 表达式</span><br><span style="font-family: 仿宋; font-size: 15px;">表达式是JasperReports的核心特征。它是一个重要的机制,允许操纵和显示报告数据,执行各种计算,自定义报告的外观和报告对象的可视性。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">1)一个典型的表达式</span><br><span style="font-family: 仿宋; font-size: 15px;">$F{LastName} + " " + $F{LastName}</span><br><span style="font-family: 仿宋; font-size: 15px;">一个JasperReports的表达式是以Java表达式为基础的,再加上一些附加的语法,它允许引用参数、变量和字段等。</span><br><span style="font-family: 仿宋; font-size: 15px;">比如说要引用一个名叫DATA的参数时,语法应为$P{PARAM_NAME}。</span><br><span style="font-family: 仿宋; font-size: 15px;">对变量和字段来说,其引用语法分别为$V{VAR_NAME}和$F{FIELD_NAME}。</span><br><span style="font-family: 仿宋; font-size: 15px;">注意:在JasperReports的groovy脚本语言中,也同样可以用$F,$P,$V引用参数、变量和字段。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">2)表达式的语法</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)$F{FIELD}   引用名为FIELD的字段;</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)$V{VAR}     引用名为VAR的变量;</span><br><span style="font-family: 仿宋; font-size: 15px;">(3)$P{PARAM}   引用名为PARAM的参数;</span><br><span style="font-family: 仿宋; font-size: 15px;">(4)$P!{PARAM} 引用名为PARAM的参数;这个特殊的语法仅能用于report的查询中。它允许插入参数的内容到查询字符串中。例如,它能被用于创建一个带通过参数来指定WHERE条件的动态查询。</span><br><span style="font-family: 仿宋; font-size: 15px;">$R{keyName}      在resource bundle中检索带keyName关键字的字符串。</span><br><span style="font-family: 仿宋; font-size: 15px;">注意:表达式是用Java或Groovy写成的,这意外着可以用Java强大的功能,如调用方法,允许构建无限复杂的表达式。还要注意,表达式的结果总是一个对象。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">3)更多的表达式</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)new Integer(Math.max($V{Price1},$V{Price2}))</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)(new SimpleDateFormat("dd/MM/yyyy")).format($F{OrderDate})</span><br><span style="font-family: 仿宋; font-size: 15px;">(3)$F{SpecialOffer}.booleanValue()? $F{SpecialPrice} : $F{Price}</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">2、内建的函数</span><br><span style="font-family: 仿宋; font-size: 15px;">JasperReports提供了一套内建的函数用于report表达式中。这些函数尽管是内建的工具,还是可以在普通操作中执行它。</span><br><span style="font-family: 仿宋; font-size: 15px;">注意:目前这套函数很有限,在未来会得到扩展。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">1)例:使用内建函数</span><br><span style="font-family: 仿宋; font-size: 15px;">msg("Total cost is {0}", $F{TOTAL})</span><br><span style="font-family: 仿宋; font-size: 15px;">msg("Matched {0} products out of {1}", $F{MATCHED}, $P{TOTAL})</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">2)内建的函数</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)String str(String key);</span><br><span style="font-family: 仿宋; font-size: 15px;">从和report相联系的resource bundle中得到给出的key的一个字符串。这个函数的功能和使用$R{key}语法等价。</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)String msg(String pattern, Object arg0);</span><br><span style="font-family: 仿宋; font-size: 15px;">建立一个带给定的pattern和给定参数来指定其格式的java.util.MessageFormat对象。</span><br><span style="font-family: 仿宋; font-size: 15px;">(3)String msg(String pattern, Object arg0, Object arg1);</span><br><span style="font-family: 仿宋; font-size: 15px;">同上;</span><br><span style="font-family: 仿宋; font-size: 15px;">(4)String msg(String pattern, Object arg0, Object arg1, Object arg2);</span><br><span style="font-family: 仿宋; font-size: 15px;">同上。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">3、Report 报告</span><br><span style="font-family: 仿宋; font-size: 15px;">Report是表现为报告模板的根对象。在报告执行期间,report模板和数据组合成最终的文档。</span><br><span style="font-family: 仿宋; font-size: 15px;">报告的属性有:</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)Report Name 报告名;</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)Units 报告的单位;有:像素Pixels,毫米Millimeters,厘米Centimeters和英寸Inches。</span><br><span style="font-family: 仿宋; font-size: 15px;">(3)Language 报告表达式使用的语言;目前有Java和Groovy两种。</span><br><span style="font-family: 仿宋; font-size: 15px;">(4)Orientation 页的方向;其可能值为水平Protrait和纵向Landscape。</span><br><span style="font-family: 仿宋; font-size: 15px;">(5)Page Width 以报告单位指定的页宽;</span><br><span style="font-family: 仿宋; font-size: 15px;">(6)Page Height 以报告单位指定的页高;</span><br><span style="font-family: 仿宋; font-size: 15px;">(7)Page Size 报告的尺寸,即为page width和page height。</span><br><span style="font-family: 仿宋; font-size: 15px;">(8)Left Margin 以报告单位指定的左边页边距;</span><br><span style="font-family: 仿宋; font-size: 15px;">(9)Right Margin 以报告单位指定的右边页边距;</span><br><span style="font-family: 仿宋; font-size: 15px;">(10)Top Margin 以报告单位指定的顶部页边距;</span><br><span style="font-family: 仿宋; font-size: 15px;">(11)Bottom Margin 以报告单位指定的底部页边距;</span><br><span style="font-family: 仿宋; font-size: 15px;">(12)Column Count 报告中的列数;</span><br><span style="font-family: 仿宋; font-size: 15px;">(13)Column Spacing 以报告单位指定的列边距;</span><br><span style="font-family: 仿宋; font-size: 15px;">(14)Column Width 以报告单位指定的列宽;</span><br><span style="font-family: 仿宋; font-size: 15px;">(15)Print Order 填充列的顺序;有垂直Vertical和水平Horizontal两种。</span><br><span style="font-family: 仿宋; font-size: 15px;">(16)Float Column Footer 浮动列脚,指出是否在列底部或明细表最后或组脚进行打印;</span><br><span style="font-family: 仿宋; font-size: 15px;">(17)Default Font 缺省字体;</span><br><span style="font-family: 仿宋; font-size: 15px;">(18)Default Style 缺省风格;</span><br><span style="font-family: 仿宋; font-size: 15px;">(19)Scriptlet Class 脚本类,它必须是JRAbstractScriptlet类的子类。如果省略,将创建一个JRDefaultScriptlet的实例。</span><br><span style="font-family: 仿宋; font-size: 15px;">(20)Summary New Page 新页的概要;</span><br><span style="font-family: 仿宋; font-size: 15px;">(21)Title New Page 新页的标题;</span><br><span style="font-family: 仿宋; font-size: 15px;">(22)When No Data Print 无数据时的打印,有三个选择:No Pages 表示0页;Blank Page 空白页;All Sections No Detail 除了detail section,其它的都打印。</span><br><span style="font-family: 仿宋; font-size: 15px;">(23)Query 查询,用来检索数据到报告中。</span><br><span style="font-family: 仿宋; font-size: 15px;">(24)Query Language 查询语言,有五个值:SQL 用于JDBC数据源的查询语言;HBM Hibernate用于Hibernate数据源的查询语言;XPath 用于XML数据源的查询语言;EJBQL用于支持Java持久层(Persistence)API的数据源的查询语言;MDX 用于Mondrian数据源的查询语言。</span><br><span style="font-family: 仿宋; font-size: 15px;">(25)Imports java输入的列表,例如:java.util.*和java.text.SimpleDateFormat格式。用于简化report的表达式。</span><br><span style="font-family: 仿宋; font-size: 15px;">(26)Resource Bundle 为report提供了本地的系列字符串。在报告中,本地字符串能用$R{key}引用。</span><br><span style="font-family: 仿宋; font-size: 15px;">(27)When Resource Missing Print 允许自定义引擎在resource bundle中处理丢失的resource。有4种选择:Null 丢失的resource不打印;Empty 丢失的resource为空;Key 用$R{key}指定的key来打印; Error 用错误来中断报告的执行。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">4、Styles 风格</span><br><span style="font-family: 仿宋; font-size: 15px;">一个report可以定义大量的风格。一旦定义了,它们能和report对象联系起来,为了给各种可视视图提供基本的配置。report允许用模块化的方式来定义模块的风格。</span><br><span style="font-family: 仿宋; font-size: 15px;">风格有相关联的条件风格。条件风格允许当其表达式为真时改变风格。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">1)风格的属性有:</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)Name 风格名;</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)Parent Style 父风格;</span><br><span style="font-family: 仿宋; font-size: 15px;">(3)Foreground 前景色;</span><br><span style="font-family: 仿宋; font-size: 15px;">(4)Background 背景色;</span><br><span style="font-family: 仿宋; font-size: 15px;">(5)Mode 方式,决定是否带透明度;</span><br><span style="font-family: 仿宋; font-size: 15px;">(6)Pen 画笔 有6种选择:None 无线;1 Point 正常宽度的线;2 Point 中等宽度的线;4 Point 粗线;Dotted 虚线;Thin 细线。</span><br><span style="font-family: 仿宋; font-size: 15px;">(7)Fill 填充;决定对对象进行填充的模式;</span><br><span style="font-family: 仿宋; font-size: 15px;">(8)Box 指定盒子的属性,如边框类型,边框颜色,是否填充。</span><br><span style="font-family: 仿宋; font-size: 15px;">(9)Horizontal Alignment 水平排列;有3种选择:Left 左;Center 中;Right 右。</span><br><span style="font-family: 仿宋; font-size: 15px;">(10)Vertical Alignment 垂直排列;有3种选择:Top 顶;Middle 中;Bottom 底。</span><br><span style="font-family: 仿宋; font-size: 15px;">(11)Scale 比例;指定图像的比例,有3种选择:Clip 尺寸不适合时,多余部分省略;Fill Frame 图像按比例填充进Image对象中;Retain Shape 保留原形状进行填充。</span><br><span style="font-family: 仿宋; font-size: 15px;">(12)Radius 指定矩形边框倒角的弧度;</span><br><span style="font-family: 仿宋; font-size: 15px;">(13)Pattern 用Text Field表达式的值来指定样式;其日期类型的值用java.text.SimpleDataFormat类来定义;其数值型的值用java.text.DecimalFormat来定义。</span><br><span style="font-family: 仿宋; font-size: 15px;">(14)Blank When Null 当Text Field表达式的值为null时显示空白;</span><br><span style="font-family: 仿宋; font-size: 15px;">(15)Line Spacing 线距;有3种选择:Single:单倍线距;1 and 1/2:1.5倍线距;Double:双倍线距。</span><br><span style="font-family: 仿宋; font-size: 15px;">(16)Rotation 旋转;有3种选择:None 不旋转;Left 左旋180度;Right 右旋180度。</span><br><span style="font-family: 仿宋; font-size: 15px;">(17)Styled Text 是一个标志位,用来指定是否text对象包含了已定义风格或规则的text。</span><br><span style="font-family: 仿宋; font-size: 15px;">(18)Font Name 字体名;</span><br><span style="font-family: 仿宋; font-size: 15px;">(19)Font Size 字体的尺寸;</span><br><span style="font-family: 仿宋; font-size: 15px;">(20)Bold 粗体;</span><br><span style="font-family: 仿宋; font-size: 15px;">(21)Italic 斜体;</span><br><span style="font-family: 仿宋; font-size: 15px;">(22)Underline 下划线;</span><br><span style="font-family: 仿宋; font-size: 15px;">(23)Strike Through 通过标准位来取消;</span><br><span style="font-family: 仿宋; font-size: 15px;">(24)PDF Font Name:PDF字体名;</span><br><span style="font-family: 仿宋; font-size: 15px;">(25)PDF Encoding:PDF编码;</span><br><span style="font-family: 仿宋; font-size: 15px;">(26)PDF Embedded是一个标志位,指定是否PDF字体应该嵌入到文档中。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">2)条件风格的属性:</span><br><span style="font-family: 仿宋; font-size: 15px;">和上面仅有一点点的不同。其不同的属性为:</span><br><span style="font-family: 仿宋; font-size: 15px;">Condition Expression 条件表达式;是一个布尔型的表达式,用于判断是否应用条件表达式。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">5、Section Properties 节属性</span><br><span style="font-family: 仿宋; font-size: 15px;">Section的种类前面已经讲了,这里只是补充讲述它的属性:</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)Height 以报告的单位指定的section的高度;</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)Print When Expression 是一个布尔表达式,决定是否打印本Section;</span><br><span style="font-family: 仿宋; font-size: 15px;">(3)Split Allowed 一个标志位,指示当Section超过当前页面的尺寸时,是否允许分割它。如果为真,当前Section将迁移到下一页。注意:如果Section在下一页也不适合时,则不管标志位值如何,都会分割它。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">6、Groups 组</span><br><span style="font-family: 仿宋; font-size: 15px;">一个report可以定义大量的组。组表示决定带相关数据的可视组的表达式名。一旦声明后,组能在报告任意地方使用。</span><br><span style="font-family: 仿宋; font-size: 15px;">一个数据组用一个表达式组来识别。</span><br><span style="font-family: 仿宋; font-size: 15px;">注意:组机制不能完成来自于数据源数据的任何排序。如果想要有序的数据,必须把数据源的数据进行先排序处理。</span><br><span style="font-family: 仿宋; font-size: 15px;">组属性:</span><br><span style="font-family: 仿宋; font-size: 15px;">(1)Name 组名;用于引用组。</span><br><span style="font-family: 仿宋; font-size: 15px;">(2)Expression 表达式;决定report数据的组;</span><br><span style="font-family: 仿宋; font-size: 15px;">(3)Min Height To Start New Page 开始新页的最小高度;</span><br><span style="font-family: 仿宋; font-size: 15px;">(4)Reprint Header On Each Page 一个标志位,指示在每一页的开始处是否重新打印组头;</span><br><span style="font-family: 仿宋; font-size: 15px;">(5)Reset Page Number 重设页数,一个标志位;在组头在新页开始处打印时,是否重新设置页数;</span><br><span style="font-family: 仿宋; font-size: 15px;">(6)Start New Column 一个标志位,是否在新列中总是打印组头;</span><br><span style="font-family: 仿宋; font-size: 15px;">(7)Start New Page 一个标志位,是否在新页中总是打印组头</span></p> 
  <h1><span style="font-family: 仿宋; font-size: 15px;">五、JasperReports作为一种开源的报表库为应用提供了强大的支持。其易用性和灵活性为系统的开发提供了极大的便利。</span></h1> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">在报表生成过程中,使用JDBC等传统数据源操作方法获取数据的过程会消耗大量的系统时间,这样就需要利用其它手段来简化数据源操作。</span><br><span style="font-family: 仿宋; font-size: 15px;">在这种情况下,适当的使用ORM(Object/Relational Mapping)技术,能够很好的解决这个问题,对于系统性能的提升有很大的帮助。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">1、JasperReports填充报表</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">要完成报表的填充,必须先完成用于报表的xml模板,其过程是先产生报表布局对象,再序列号该对象,存储在磁盘或者网络,用于产生特定应用的表格数据。</span><br><span style="font-family: 仿宋; font-size: 15px;">实际上,表单的设计过程就是用定义于xml文件中的java表达式来表现报表的布局。</span><br><span style="font-family: 仿宋; font-size: 15px;">编辑过程中会有各种保证数据一致性的验证,最终会产生相关数据的文档。</span><br><span style="font-family: 仿宋; font-size: 15px;">报表引擎必须先接受数据来产生报表,这些数据一般来源于各种数据源,报表引擎能直接接收用于填充表格的数据源对象,或者通过自身提供的JDBC连接对象来处理数据库的数据。</span><br><span style="font-family: 仿宋; font-size: 15px;">报表最终要产生一个新的对象来进行填充操作从而产生用于输出的文档对象,这也是一个存储在磁盘或者网络传输介质的序列化对象。</span><br><span style="font-family: 仿宋; font-size: 15px;">JasperReports的内置浏览器能直接查看结果或者以PDF,HTML,XML形式将其导出。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">2、持久化技术和ORM</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">持久化(Persistence),即把数据保存到可永久保存的存储设备中(如磁盘)。</span><br><span style="font-family: 仿宋; font-size: 15px;">持久化的主要应用是将内存中的数据存储在关系型的数据库中,当然也可以存储在磁盘文件中、XML数据文件中等。</span><br><span style="font-family: 仿宋; font-size: 15px;">ORM即“对象-关系型数据映射组件。对于O/R,即Object(对象)和Relational(关系型数据),表示必须同时使用面向对象和关系型数据进行开发。</span><br><span style="font-family: 仿宋; font-size: 15px;">MVC(Model View Control)中的Model包含了复杂的业务逻辑和数据逻辑,以及数据存取机制(如JDBC的连接、SQL生成和Statement创建、还要ResultSet结果集的读取等)。将这些复杂的业务逻辑和数据逻辑分离,以将系统的紧耦合关系转化为松耦合关系(即解耦合),是降低系统耦合度迫切要做的,也是持久化要做的工作。</span><br><span style="font-family: 仿宋; font-size: 15px;">MVC模式实现了架构上将表现层和数据处理层分离的解耦合,而持久化设计则实现了数据处理层内部的业务逻辑和数据逻辑分离的解耦合。</span><br><span style="font-family: 仿宋; font-size: 15px;">关系型数据库中的数据基本都是以一行行的数据进行存取的,而程序运行却是一个个对象进行处理,而目前大部分数据库驱动技术(如ADO.NET、JDBC、ODBC等)均是以行集的结果集一条条进行处理的。所以为解决这一困难,就出现ORM这一个对象和数据之间映射技术。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">3、在JasperReports中使用Hibernate</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">Hibernate是一个开发源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。</span><br><span style="font-family: 仿宋; font-size: 15px;">Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。</span></p> 
  <p style="margin-left: 30px;"><span style="font-size: 18px;"><strong><span style="font-family: 仿宋;">关键代码片段</span></strong></span></p> 
  <p style="margin-left: 30px;"> </p> 
  <div class="cnblogs_code"> 
   <pre><span style="color: #0000ff;">package</span><span style="color: #000000;"> src;

</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> java.util.HashMap;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> java.util.List;

</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> net.sf.jasperreports.engine.JRException;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> net.sf.jasperreports.engine.JasperCompileManager;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> net.sf.jasperreports.engine.JasperFillManager;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> net.sf.jasperreports.engine.JasperPrint;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> net.sf.jasperreports.engine.JasperReport;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> net.sf.jasperreports.engine.design.JasperDesign;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> net.sf.jasperreports.engine.xml.JRXmlLoader;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> net.sf.jasperreports.engine.JasperExportManager;

</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> org.hibernate.HibernateException;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> org.hibernate.MappingException;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> org.hibernate.Session;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> org.hibernate.SessionFactory;
</span><span style="color: #0000ff;">import</span><span style="color: #000000;"> org.hibernate.cfg.Configuration;

</span><span style="color: #0000ff;">public</span> <span style="color: #0000ff;">class</span><span style="color: #000000;"> Simple1 {
</span><span style="color: #0000ff;">public</span> <span style="color: #0000ff;">static</span> <span style="color: #0000ff;">void</span><span style="color: #000000;"> main(String args[]) {
   String sampleReportFile</span>=<span style="color: #0000ff;">new</span> String("reports/sampleReport.jrxml"<span style="color: #000000;">);
   </span><span style="color: #008000;">//</span><span style="color: #008000;">Hibernate Result Set Holder.</span>
   List bowlerInfo=<span style="color: #0000ff;">null</span><span style="color: #000000;">;
   </span><span style="color: #0000ff;">try</span><span style="color: #000000;"> {
    </span><span style="color: #008000;">//</span><span style="color: #008000;">Configure the Hibernate session</span>
    Configuration cfg=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Configuration();
    cfg.addResource(</span>"hibernate-mapping.xml"<span style="color: #000000;">);
    SessionFactory sessions</span>=<span style="color: #000000;">cfg.buildSessionFactory();
    </span><span style="color: #008000;">//</span><span style="color: #008000;">Open the Hibernate Session</span>
    Session session=<span style="color: #000000;">sessions.openSession();
    </span><span style="color: #008000;">//</span><span style="color: #008000;">Returns all SampleData records.
    </span><span style="color: #008000;">//</span><span style="color: #008000;">Simple POJO object.</span>
    bowlerInfo=session.createQuery("from SampleData"<span style="color: #000000;">).list();
    </span><span style="color: #008000;">//</span><span style="color: #008000;">Fill the parameters</span>
    HashMap parameters=<span style="color: #0000ff;">new</span><span style="color: #000000;"> HashMap();
    parameters.put(</span>"ReportTitle","Bowling Scores"<span style="color: #000000;">);
    parameters.put(</span>"NoOfGames", <span style="color: #0000ff;">new</span> Integer(3<span style="color: #000000;">));
    </span><span style="color: #008000;">//</span><span style="color: #008000;">Load the sample report file from the XML file
    </span><span style="color: #008000;">//</span><span style="color: #008000;">into the JasperDesign object.</span>
    JasperDesign design=<span style="color: #000000;">JRXmlLoader.load(sampleReportFile);
    </span><span style="color: #008000;">//</span><span style="color: #008000;">Compile the Report in Memory storing it in a JasperReport object
    </span><span style="color: #008000;">//</span><span style="color: #008000;">no .jasper report file is created.</span>
    JasperReport report=<span style="color: #0000ff;">new</span><span style="color: #000000;"> JasperCompileManager().compileReport(design);
    </span><span style="color: #008000;">//</span><span style="color: #008000;">Fill the report using the JRBeanCollectionDataSource passed
    </span><span style="color: #008000;">//</span><span style="color: #008000;">a Hibernate query result set.</span>
    JasperPrint print=JasperFillManager.fillReport(report,parameters,<span style="color: #0000ff;">new</span><span style="color: #000000;"> JRBeanCollectionDataSource(bowlerInfo));
    </span><span style="color: #008000;">//</span><span style="color: #008000;">Export to PDF file.</span>
    JasperExportManager.exportReportToPdfFile(print,"simpleHibernatExample.pdf"<span style="color: #000000;">);
    </span><span style="color: #008000;">//</span><span style="color: #008000;">Close the Hibernate Session.</span>
<span style="color: #000000;">    session.close();  
   }</span><span style="color: #0000ff;">catch</span><span style="color: #000000;">(JRException jre) {
    jre.printStackTrace();
   }</span><span style="color: #0000ff;">catch</span><span style="color: #000000;">(MappingException me) {
    me.printStackTrace();
   }</span><span style="color: #0000ff;">catch</span><span style="color: #000000;">(HibernateException he) {
    he.printStackTrace();
   }
}
}</span></pre> 
  </div> 
  <p style="margin-left: 30px;"> </p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">当Hibernate检索返回集合类型的对象时,使用JRBeanCollection接口可将数据通过Hibernate的POJO(Plain Old Java Object)实例映射到报表域中,使用JRXmlLoader.load(templateName)方法加载报表模板,最后通过JasperFillManager方法将数据填入模板中。</span><br><span style="font-family: 仿宋; font-size: 15px;">本例使用JasperExportManager.exportReportToPdfFile()方法将报表输出为PDF格式。JasperReports提供的net.sf.jasperreports.engine.JRExporter接口可以方便的将报表输出为PDF、XLS、CSV、RTF、HTML或者XML格式,目前以PDF和EXCEL格式较为通用。</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">4、总结</span></p> 
  <p style="margin-left: 30px;"><span style="font-family: 仿宋; font-size: 15px;">在JasperReports中使用了Hibernate以后,如果随业务更换数据源的话,只需要更好Hibernate的映射文件,极大提高了代码的可重用性,同时由于Hibernate本身对于查询的优化,也能很好的提高整个应用的效率,尽可能的节省开发时间。</span></p> 
  <p style="margin-left: 30px;"> </p> 
 </div> 
</div>
                            </div>
                        </div>
                    </div>
                    <!--PC和WAP自适应版-->
                    <div id="SOHUCS" sid="1292373881406955520"></div>
                    <script type="text/javascript" src="/views/front/js/chanyan.js"></script>
                    <!-- 文章页-底部 动态广告位 -->
                    <div class="youdao-fixed-ad" id="detail_ad_bottom"></div>
                </div>
                <div class="col-md-3">
                    <div class="row" id="ad">
                        <!-- 文章页-右侧1 动态广告位 -->
                        <div id="right-1" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad">
                            <div class="youdao-fixed-ad" id="detail_ad_1"> </div>
                        </div>
                        <!-- 文章页-右侧2 动态广告位 -->
                        <div id="right-2" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad">
                            <div class="youdao-fixed-ad" id="detail_ad_2"></div>
                        </div>
                        <!-- 文章页-右侧3 动态广告位 -->
                        <div id="right-3" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad">
                            <div class="youdao-fixed-ad" id="detail_ad_3"></div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
    <div class="container">
        <h4 class="pt20 mb15 mt0 border-top">你可能感兴趣的:(JasperReports+iReport在eclipse中的使用)</h4>
        <div id="paradigm-article-related">
            <div class="recommend-post mb30">
                <ul class="widget-links">
                    <li><a href="/article/1902656012855341056.htm"
                           title="Django 中@login_required 配置详解" target="_blank">Django 中@login_required 配置详解</a>
                        <span class="text-muted">换个网名有点难</span>
<a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/sqlite/1.htm">sqlite</a>
                        <div>在Django中对@login_required进行配置,主要涉及全局配置和视图函数局部配置两方面,下面为你详细介绍配置方法。全局配置全局配置主要是设定默认的登录URL,也就是当未登录用户尝试访问被@login_required装饰的视图时,会被重定向到的页面。你可以在项目的settings.py文件里对这个默认的登录URL进行配置。步骤打开项目的settings.py文件。添加或修改LOGIN_</div>
                    </li>
                    <li><a href="/article/1902656013656453120.htm"
                           title="最完整的webpack Dll打包与采坑总结" target="_blank">最完整的webpack Dll打包与采坑总结</a>
                        <span class="text-muted">仰望星空的代码</span>
<a class="tag" taget="_blank" href="/search/Vue.js%E8%B8%A9%E5%9D%91%E8%AE%B0/1.htm">Vue.js踩坑记</a><a class="tag" taget="_blank" href="/search/vue.js/1.htm">vue.js</a><a class="tag" taget="_blank" href="/search/webpack/1.htm">webpack</a><a class="tag" taget="_blank" href="/search/dll%E6%89%93%E5%8C%85/1.htm">dll打包</a><a class="tag" taget="_blank" href="/search/%E6%89%93%E5%8C%85%E4%BC%98%E5%8C%96/1.htm">打包优化</a>
                        <div>webpack已经成为前端主流的项目打包工具,对于前端开发必不可少。在前端项目依赖第三方库过多,项目比较大文件比较多时,webpack打包的速度也会被拖成蜗牛,是时候优化一下webapck的打包速度了。在优化打包速度方面有不少方法方式,其中一个比较重要的方式是DllPlugin。DllPlugin把第三方库打包成动态链接库(动态链接库:windows系统中库文件概念,这里是借用了这一概念。),Dl</div>
                    </li>
                    <li><a href="/article/1902654249217617920.htm"
                           title="【C++】面向对象的三大特性:封装、继承、多态(3)" target="_blank">【C++】面向对象的三大特性:封装、继承、多态(3)</a>
                        <span class="text-muted">_Yeps</span>
<a class="tag" taget="_blank" href="/search/%E3%80%90C%2B%2B%E3%80%91%E5%9F%BA%E7%A1%80%E7%9F%A5%E8%AF%86%E8%A7%A3%E6%9E%90/1.htm">【C++】基础知识解析</a><a class="tag" taget="_blank" href="/search/c%2B%2B/1.htm">c++</a><a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95/1.htm">算法</a>
                        <div>1、面向对象的三大特性:封装、继承、多态——【C++】面向对象的三大特性:封装、继承、多态(1)详见以上链接,点击蓝字。2、C++的封装是如何实现的?——【C++】面向对象的三大特性:封装、继承、多态(2)详见以上链接,点击蓝字。3、C++的继承是如何实现的?在C++中,继承是通过:(冒号)+访问控制修饰符(public、protected、private)实现的。class父类{//父类的成员}</div>
                    </li>
                    <li><a href="/article/1902654122935513088.htm"
                           title="List 和 Set 的区别" target="_blank">List 和 Set 的区别</a>
                        <span class="text-muted">不会搬砖的淡水鱼</span>
<a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84/1.htm">数据结构</a><a class="tag" taget="_blank" href="/search/list/1.htm">list</a><a class="tag" taget="_blank" href="/search/windows/1.htm">windows</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84/1.htm">数据结构</a>
                        <div>List和Set的区别在Java中,List和Set都是Collection接口的子接口,但它们的存储结构、特点、使用场景不同。对比项List(有序、可重复)Set(无序、不可重复)是否允许重复元素✅允许❌不允许是否有序✅按插入顺序排序❌无序(TreeSet除外)是否可以有null✅允许多个null✅只允许一个null底层数据结构数组、链表哈希表、红黑树访问方式通过索引访问通过iterator遍历</div>
                    </li>
                    <li><a href="/article/1902653870694264832.htm"
                           title="RSA加密算法" target="_blank">RSA加密算法</a>
                        <span class="text-muted">不会搬砖的淡水鱼</span>
<a class="tag" taget="_blank" href="/search/%E7%BD%91%E7%BB%9C/1.htm">网络</a><a class="tag" taget="_blank" href="/search/%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">服务器</a><a class="tag" taget="_blank" href="/search/%E5%AE%89%E5%85%A8/1.htm">安全</a>
                        <div>RSA加密算法:数学魔术背后的安全守护者RSA加密算法(Rivest-Shamir-Adleman)是一种广泛使用的公钥加密算法,它在信息安全领域具有重要作用。RSA是由罗纳德·李维斯特(RonRivest)、阿迪·萨莫尔(AdiShamir)和伦纳德·阿德曼(LeonardAdleman)在1977年一起提出的。当时他们三人都在麻省理工学院工作。RSA就是他们三人姓氏开头字母拼在一起组成的。RS</div>
                    </li>
                    <li><a href="/article/1902653743145480192.htm"
                           title="基础算法--背包问题" target="_blank">基础算法--背包问题</a>
                        <span class="text-muted">不会搬砖的淡水鱼</span>
<a class="tag" taget="_blank" href="/search/%E5%9F%BA%E7%A1%80%E7%AE%97%E6%B3%95/1.htm">基础算法</a><a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95/1.htm">算法</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%8A%A8%E6%80%81%E8%A7%84%E5%88%92/1.htm">动态规划</a><a class="tag" taget="_blank" href="/search/%E8%B4%AA%E5%BF%83%E7%AE%97%E6%B3%95/1.htm">贪心算法</a>
                        <div>背包问题概念完全背包(无限背包)0-1背包概念背包问题是一个经典的组合优化问题,其目标是在给定的一组物品中选择一些物品放入背包中,使得物品的总价值最大化,同时要求背包的总重量不超过背包的容量限制。背包问题有两种常见的变体:完全背包和0-1背包。鉴于完全背包计算过程相对0-1背包简单,这里先讲完全背包。完全背包(无限背包)在完全背包问题中,每个物品可以选择放入背包中的次数是无限的,即可以重复选择。每</div>
                    </li>
                    <li><a href="/article/1902653364714401792.htm"
                           title="数据操作与事务:确保数据一致性的关键" target="_blank">数据操作与事务:确保数据一致性的关键</a>
                        <span class="text-muted">qcidyu</span>
<a class="tag" taget="_blank" href="/search/%E8%BD%AF%E4%BB%B6%E5%BC%80%E5%8F%91/1.htm">软件开发</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93%E8%A7%84%E5%88%99/1.htm">数据库规则</a>
                        <div>title:数据操作与事务:确保数据一致性的关键date:2025/2/11updated:2025/2/11author:cmdragonexcerpt:在现代数据管理中,事务处理是确保数据完整性和一致性的重要机制。本文将深入探讨事务的ACID特性、锁机制及其种类(行级锁与表级锁)以及事务隔离级别(READUNCOMMITTED、READCOMMITTED、REPEATABLEREAD、SERI</div>
                    </li>
                    <li><a href="/article/1902653238423908352.htm"
                           title="Java WebSocket与项目页面(通常是HTML + JavaScript)之间建立连接并传输数据" target="_blank">Java WebSocket与项目页面(通常是HTML + JavaScript)之间建立连接并传输数据</a>
                        <span class="text-muted">hh_fine</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/websocket/1.htm">websocket</a><a class="tag" taget="_blank" href="/search/html/1.htm">html</a>
                        <div>JavaWebSocket与项目页面(通常是HTML+JavaScript)之间建立连接并传输数据1.创建JavaWebSocket服务器:使用JavaWebSocketAPI创建一个WebSocket服务器端点。2.在HTML页面中使用JavaScript连接WebSocket:通过JavaScript的WebSocketAPI与JavaWebSocket服务器建立连接。3.双向数据传输:实现服</div>
                    </li>
                    <li><a href="/article/1902653112125026304.htm"
                           title="RuoYi框架连接SQL Server时解决“SSL协议不支持”和“加密协议错误”" target="_blank">RuoYi框架连接SQL Server时解决“SSL协议不支持”和“加密协议错误”</a>
                        <span class="text-muted">专注代码十年</span>
<a class="tag" taget="_blank" href="/search/ssl/1.htm">ssl</a><a class="tag" taget="_blank" href="/search/%E7%BD%91%E7%BB%9C%E5%8D%8F%E8%AE%AE/1.htm">网络协议</a><a class="tag" taget="_blank" href="/search/%E7%BD%91%E7%BB%9C/1.htm">网络</a>
                        <div>RuoYi框架连接SQLServer时解决“SSL协议不支持”和“加密协议错误”在使用RuoYi框架进行开发时,与SQLServer数据库建立连接可能会遇到SSL协议相关的问题。以下是两个常见的错误信息及其解决方案。错误信息1com.zaxxer.hikari.pool.HikariPool$PoolInitializationException:Failedtoinitializepool;'e</div>
                    </li>
                    <li><a href="/article/1902652859506290688.htm"
                           title="深入解析 MySQL 数据库:隔离级别的选择" target="_blank">深入解析 MySQL 数据库:隔离级别的选择</a>
                        <span class="text-muted">幽兰的天空</span>
<a class="tag" taget="_blank" href="/search/MYSQL%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">MYSQL数据库</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a><a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/oracle/1.htm">oracle</a>
                        <div>在数据库中,创建事务一般包含几个简单的步骤。以下是如何在MySQL中创建事务的基本指南,包括相关的SQL语句和操作流程:1.启动事务在MySQL中,你可以使用STARTTRANSACTION或BEGIN语句来启动一个新的事务。这表示你将开始执行一系列操作,这些操作要么全部成功(提交),要么全部失败(回滚)。STARTTRANSACTION;--或者使用BEGIN;2.执行操作在事务被启动后,你可以</div>
                    </li>
                    <li><a href="/article/1902652229874151424.htm"
                           title="2003-2022年 上市公司-企业海外业务收入数据-社科数据" target="_blank">2003-2022年 上市公司-企业海外业务收入数据-社科数据</a>
                        <span class="text-muted">泡芙萝莉酱</span>
<a class="tag" taget="_blank" href="/search/%E5%A4%A7%E6%95%B0%E6%8D%AE/1.htm">大数据</a><a class="tag" taget="_blank" href="/search/%E7%A4%BE%E7%A7%91%E6%95%B0%E6%8D%AE/1.htm">社科数据</a><a class="tag" taget="_blank" href="/search/%E5%A4%A7%E6%95%B0%E6%8D%AE/1.htm">大数据</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%88%86%E6%9E%90/1.htm">数据分析</a><a class="tag" taget="_blank" href="/search/%E6%B7%B1%E5%BA%A6%E5%AD%A6%E4%B9%A0/1.htm">深度学习</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E6%8C%96%E6%8E%98/1.htm">数据挖掘</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E7%BB%9F%E8%AE%A1/1.htm">数据统计</a><a class="tag" taget="_blank" href="/search/%E6%AF%95%E4%B8%9A%E8%AE%BA%E6%96%87/1.htm">毕业论文</a>
                        <div>上市公司-企业海外业务收入数据(2003-2022年)-社科数据https://download.csdn.net/download/paofuluolijiang/90027750https://download.csdn.net/download/paofuluolijiang/90027750上市公司海外业务收入是指企业通过在海外市场开展业务所获得的收入,包括出口产品或服务、在海外设立子公司</div>
                    </li>
                    <li><a href="/article/1902650464785199104.htm"
                           title="CUDA编程基础" target="_blank">CUDA编程基础</a>
                        <span class="text-muted">清 澜</span>
<a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95%E9%9D%A2%E8%AF%95/1.htm">算法面试</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/c%2B%2B/1.htm">c++</a><a class="tag" taget="_blank" href="/search/%E7%AE%97%E6%B3%95/1.htm">算法</a><a class="tag" taget="_blank" href="/search/nvidia/1.htm">nvidia</a><a class="tag" taget="_blank" href="/search/cuda%E7%BC%96%E7%A8%8B/1.htm">cuda编程</a>
                        <div>一、快速理解CUDA编程1.1CUDA简介CUDA(ComputeUnifiedDeviceArchitecture)是由NVIDIA推出的并行计算平台和应用程序接口模型。它允许开发者利用NVIDIAGPU的强大计算能力来加速通用计算任务,而不仅仅是图形渲染。通过CUDA,开发者可以编写C、C++或Fortran代码,并将其扩展以在GPU上运行,从而显著提高性能,特别是在处理大规模数据集和复杂算法</div>
                    </li>
                    <li><a href="/article/1902650338264018944.htm"
                           title="使用bat批量获取WORD中包含对应字符的段落,段落使用回车换行" target="_blank">使用bat批量获取WORD中包含对应字符的段落,段落使用回车换行</a>
                        <span class="text-muted">宇宙无敌花心大萝卜</span>
<a class="tag" taget="_blank" href="/search/%E6%89%B9%E5%A4%84%E7%90%86/1.htm">批处理</a><a class="tag" taget="_blank" href="/search/%E6%96%87%E6%A1%A3%E5%A4%84%E7%90%86/1.htm">文档处理</a><a class="tag" taget="_blank" href="/search/word/1.htm">word</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/bat/1.htm">bat</a><a class="tag" taget="_blank" href="/search/%E6%89%B9%E5%A4%84%E7%90%86/1.htm">批处理</a><a class="tag" taget="_blank" href="/search/VBS/1.htm">VBS</a>
                        <div>get_word_paragraphs.vbs'获取命令行参数IfWScript.Arguments.Count=0ThenWScript.Quit1EndIf'获取Word文档路径docPath=WScript.Arguments(0)'创建Word应用程序对象SetobjWord=CreateObject("Word.Application")objWord.Visible=False'打开W</div>
                    </li>
                    <li><a href="/article/1902649330712506368.htm"
                           title="Django系列教程(13)——Cookie和Session应用场景及案例" target="_blank">Django系列教程(13)——Cookie和Session应用场景及案例</a>
                        <span class="text-muted">l软件定制开发工作室</span>
<a class="tag" taget="_blank" href="/search/Django%E6%95%99%E7%A8%8B/1.htm">Django教程</a><a class="tag" taget="_blank" href="/search/django/1.htm">django</a>
                        <div>目录什么是cookie,cookie的应用场景及缺点Django中如何使用cookieCookie使用示例什么是session及session的工作原理Django中如何使用会话sessionSession使用示例小结HTTP协议本身是”无状态”的,在一次请求和下一次请求之间没有任何状态保持,服务器无法识别来自同一用户的连续请求。有了cookie和session,服务器就可以利用它们记录客户端的访</div>
                    </li>
                    <li><a href="/article/1902649330234355712.htm"
                           title="AI编程的心得体会" target="_blank">AI编程的心得体会</a>
                        <span class="text-muted">猜测7</span>
<a class="tag" taget="_blank" href="/search/AI%E7%BC%96%E7%A8%8B/1.htm">AI编程</a><a class="tag" taget="_blank" href="/search/chatgpt/1.htm">chatgpt</a>
                        <div>最近使用了三款AI软件进行编程,真的是一款比一款好用,很大程度提高了写代码的效率,真的非常方便。首先是豆包的插件Marscode,我知道它B站首页曾经见到一个推荐,标题大意是不写一行代码开发出一个打砖块的游戏。我对着视频试了一遍,在VSCode中可以直接搜索安装Marscode,用的phython写的小游戏,结果发现其实最核心的架构玩法其实都在它clonegithub那步,就是把已经能运行的游戏拿</div>
                    </li>
                    <li><a href="/article/1902648069812449280.htm"
                           title="Python 的类中,self 是一个特殊的参数" target="_blank">Python 的类中,self 是一个特殊的参数</a>
                        <span class="text-muted">可可乐不加冰</span>
<a class="tag" taget="_blank" href="/search/%E7%9F%A5%E8%AF%86%E5%AD%A6%E4%B9%A0%E4%B8%93%E6%A0%8F/1.htm">知识学习专栏</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>在Python的类中,self是一个特殊的参数,它代表类的实例本身。self是方法的第一个参数,用于访问实例的属性和方法。下面我将从多个角度解释self的含义、作用以及如何使用它。1.self表示类的实例本身在Python中,当你创建一个类的实例时,实际上是在内存中创建了一个对象。self参数代表的就是这个对象本身。通过self,你可以在类的方法中访问和修改实例的属性。2.为什么需要self?se</div>
                    </li>
                    <li><a href="/article/1902647440083841024.htm"
                           title="Trae AI 上新 SSHremote:服务器 Python 接口日志排查实战指南" target="_blank">Trae AI 上新 SSHremote:服务器 Python 接口日志排查实战指南</a>
                        <span class="text-muted">芯作者</span>
<a class="tag" taget="_blank" href="/search/DD%EF%BC%9A%E6%97%A5%E8%AE%B0/1.htm">DD:日记</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/%E6%B7%B1%E5%BA%A6%E5%AD%A6%E4%B9%A0/1.htm">深度学习</a><a class="tag" taget="_blank" href="/search/%E6%9C%BA%E5%99%A8%E5%AD%A6%E4%B9%A0/1.htm">机器学习</a>
                        <div>在当今的软件开发中,服务器端的稳定性和可靠性至关重要。然而,生产环境中的问题往往难以预测,尤其是接口返回502错误却无日志记录的情况,更是让开发者头疼不已。幸运的是,字节跳动推出的AI原生IDE——Trae,近期上线的SSHremote功能,为远程服务器日志排查提供了全新的解决方案。本文将结合实战案例,深入探讨如何利用TraeAI的SSHremote功能高效排查Python接口日志问题,并分享创新</div>
                    </li>
                    <li><a href="/article/1902646431789936640.htm"
                           title="前端开发:Webpack的使用总结" target="_blank">前端开发:Webpack的使用总结</a>
                        <span class="text-muted">三掌柜666</span>
<a class="tag" taget="_blank" href="/search/web%E5%89%8D%E7%AB%AF%E7%9F%A5%E8%AF%86%E6%B1%87%E6%80%BB/1.htm">web前端知识汇总</a><a class="tag" taget="_blank" href="/search/webpack/1.htm">webpack</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/javascript/1.htm">javascript</a>
                        <div>前言在前端开发过程中,尤其是现在前端框架的频繁使用的当下,作为前端开发者想必对于Webpack并不陌生,尤其是在使用Vue框架做前端开发的时候,打包时候必用Webpack。还有就是在前端求职面试的时候,Webpack相关的知识点也是面试官必定考察的,那么本篇博文就来分享一下关于Webpack使用相关的知识点,记录下来,方便后期查阅使用。Webpack概念Webpack其实是一个前端资源加载/打包工</div>
                    </li>
                    <li><a href="/article/1902646305474277376.htm"
                           title="Python后端学习系列(10):分布式系统与数据一致性(使用分布式锁、分布式事务等)" target="_blank">Python后端学习系列(10):分布式系统与数据一致性(使用分布式锁、分布式事务等)</a>
                        <span class="text-muted">DoYangTan</span>
<a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0/1.htm">学习</a><a class="tag" taget="_blank" href="/search/%E5%88%86%E5%B8%83%E5%BC%8F/1.htm">分布式</a>
                        <div>Python后端学习系列(10):分布式系统与数据一致性(使用分布式锁、分布式事务等)前言随着业务规模的不断扩大以及对系统性能、可扩展性的更高要求,后端应用往往会朝着分布式系统的方向发展。然而,分布式系统带来诸多优势的同时,也面临着如数据一致性等复杂的挑战。本期我们就聚焦于分布式系统中的关键问题——数据一致性,深入探讨分布式锁、分布式事务等相关知识以及保障数据一致性的策略与实践,让我们一起深入学习</div>
                    </li>
                    <li><a href="/article/1902646178659495936.htm"
                           title="泛目录程序:2025快云站群程序的SEO优化功能" target="_blank">泛目录程序:2025快云站群程序的SEO优化功能</a>
                        <span class="text-muted">云惠科技</span>
<a class="tag" taget="_blank" href="/search/%E5%A4%A7%E6%95%B0%E6%8D%AE/1.htm">大数据</a><a class="tag" taget="_blank" href="/search/%E6%B3%9B%E7%9B%AE%E5%BD%95/1.htm">泛目录</a>
                        <div>快云站群程序的SEO优化功能围绕搜索引擎算法设计,具体包含以下核心模块:1.关键词智能布局密度检测与优化:自动分析内容关键词密度,建议合理区间(2%-8%),避免堆砌或遗漏;多词策略支持:可针对单篇内容设置主关键词+长尾词组合,覆盖更多搜索场景;标题/摘要自动生成:根据关键词智能生成高点击率的标题和Meta描述,提升搜索展示效果。2.内链自动化系统内容关联推荐:基于语义分析,自动在文章中插入相关内</div>
                    </li>
                    <li><a href="/article/1902646179129257984.htm"
                           title="如何使用C# 读写西门子PLC" target="_blank">如何使用C# 读写西门子PLC</a>
                        <span class="text-muted">A_nanda</span>
<a class="tag" taget="_blank" href="/search/%E8%A5%BF%E9%97%A8%E5%AD%90/1.htm">西门子</a>
                        <div>在C#WPF应用程序中,与西门子S7系列PLC进行通信是一个常见的需求,尤其是在工业自动化领域。以下是三种实现WPF上位机与西门子S7系列PLC通信同步的方式,每种方式都提供了代码实例、优缺点和使用场景。1.使用S7.Net库代码示例://创建PLC连接varplc=newS7.Net.Plc(CpuType.S71500,"192.168.1.10",0,1);plc.Open();//读取PL</div>
                    </li>
                    <li><a href="/article/1902645926619574272.htm"
                           title="《壹起航:15 年助力中国工厂海外获客,开启全球化新篇》" target="_blank">《壹起航:15 年助力中国工厂海外获客,开启全球化新篇》</a>
                        <span class="text-muted">yiqijianzhan</span>
<a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/%E5%A4%A7%E6%95%B0%E6%8D%AE/1.htm">大数据</a>
                        <div>在全球化的汹涌浪潮中,无数中国工厂渴望在海外市场一展宏图。然而,一系列棘手的问题摆在他们面前:怎样成功塑造品牌形象?怎样稳定获取询盘?怎样合理控制营销成本?壹起航,凭借15年深厚的行业积累,整合外贸建站、搜索引擎优化(SEO)以及海外短视频营销等多元服务,为中国工厂开辟出一条轻松拓展海外市场、赢得更多精准订单的便捷之路。一、外贸独立站——企业出海的关键起点在海外市场这片广阔天地里,企业官网不仅是展</div>
                    </li>
                    <li><a href="/article/1902645422657171456.htm"
                           title="大小仅54K,可是效果很棒" target="_blank">大小仅54K,可是效果很棒</a>
                        <span class="text-muted">海斗星河</span>
<a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E7%94%B5%E8%84%91/1.htm">电脑</a><a class="tag" taget="_blank" href="/search/%E6%99%BA%E8%83%BD%E6%89%8B%E6%9C%BA/1.htm">智能手机</a>
                        <div>大家在使用公众号编辑器时,都遇到过图片数量限制的问题。一旦达到50张或100张,编辑器就满了,只能手动删除。每次删这么多张图片,手都点麻了。为了提高效率,我之前一直用寒星鼠标连点器,它确实挺好用的。今天,我要给大家介绍一款更强大的鼠标连点器,功能比寒星更出色,有需要的小伙伴一定要及时收藏!软件介绍今天给大家介绍的这款软件叫**鼠标录制器**,它的体积非常小巧,只有54K,是一款绿色单文件版的鼠标连</div>
                    </li>
                    <li><a href="/article/1902644793004060672.htm"
                           title="Spring使用@Async出现循环依赖原因以及解决方案" target="_blank">Spring使用@Async出现循环依赖原因以及解决方案</a>
                        <span class="text-muted">2401_89793006</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/spring/1.htm">spring</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a>
                        <div>场景复现1、首先项目需要打开spring的异步开关,在application主类上加@EnableAsync2、创建一个包含了@Async方法的异步类MessageService:@ServicepublicclassMessageService{@ResourceprivateTaskServicetaskService;@Asyncpublicvoidsend(){taskService.sh</div>
                    </li>
                    <li><a href="/article/1902644790525227008.htm"
                           title="掌握C#企业级应用的数据一致性与分布式事务:从基础到高级的全面解析" target="_blank">掌握C#企业级应用的数据一致性与分布式事务:从基础到高级的全面解析</a>
                        <span class="text-muted">墨夶</span>
<a class="tag" taget="_blank" href="/search/C%23%E5%AD%A6%E4%B9%A0%E8%B5%84%E6%96%991/1.htm">C#学习资料1</a><a class="tag" taget="_blank" href="/search/c%23/1.htm">c#</a><a class="tag" taget="_blank" href="/search/%E5%88%86%E5%B8%83%E5%BC%8F/1.htm">分布式</a><a class="tag" taget="_blank" href="/search/wpf/1.htm">wpf</a>
                        <div>在当今的企业级应用开发中,确保数据的一致性是至关重要的。尤其是在涉及分布式系统时,如何处理跨服务、跨数据库的操作以保证数据的一致性和可靠性成为了一个复杂但必须解决的问题。本文将深入探讨使用C#进行企业级应用开发时的数据一致性和分布式事务管理,提供详细的代码示例和最佳实践。第一部分:理解数据一致性与分布式事务的基础知识1.1数据一致性的重要性在企业级应用中,数据一致性是指关联数据之间的逻辑关系是否正</div>
                    </li>
                    <li><a href="/article/1902640886592892928.htm"
                           title="变频器干扰诊断三步法:排查、定位、抑制详解" target="_blank">变频器干扰诊断三步法:排查、定位、抑制详解</a>
                        <span class="text-muted">集思广益的灰太狼</span>
<a class="tag" taget="_blank" href="/search/%E5%8F%98%E9%A2%91%E5%99%A8%E5%B9%B2%E6%89%B0%E8%A7%A3%E5%86%B3%E6%96%B9%E6%A1%88/1.htm">变频器干扰解决方案</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E7%89%87%E6%9C%BA/1.htm">单片机</a><a class="tag" taget="_blank" href="/search/%E5%B5%8C%E5%85%A5%E5%BC%8F%E7%A1%AC%E4%BB%B6/1.htm">嵌入式硬件</a>
                        <div>前言众所周知变频器(VFD-VariableFrequencyDrive)在工业控制领域应用非常的广泛,它通过调节电机的频率和电压来精确控制电机的转速和扭矩,来实现节能和精准控制。然而,变频器在工作过程中会产生各种电磁干扰(EMI-ElectromagneticInterference),这些干扰可能导致控制系统误动作、通信中断、测量仪表失准等一系列问题。今天我们将系统性地介绍变频器干扰的"三步诊</div>
                    </li>
                    <li><a href="/article/1902640760260456448.htm"
                           title="【机器视觉】少量样本图片情况下的图片识别技术方案" target="_blank">【机器视觉】少量样本图片情况下的图片识别技术方案</a>
                        <span class="text-muted">yuanpan</span>
<a class="tag" taget="_blank" href="/search/%E6%9C%BA%E5%99%A8%E5%AD%A6%E4%B9%A0/1.htm">机器学习</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/%E8%AE%A1%E7%AE%97%E6%9C%BA%E8%A7%86%E8%A7%89/1.htm">计算机视觉</a>
                        <div>在只有少量图片样本的情况下,进行图像识别是一个具有挑战性的任务。以下是一些应对小样本问题的有效方案:1.数据增强(DataAugmentation)通过对现有样本进行各种变换来生成更多的训练数据,例如:几何变换:旋转、缩放、平移、翻转等。颜色变换:调整亮度、对比度、饱和度等。噪声添加:高斯噪声、椒盐噪声等。裁剪和填充:随机裁剪图像的一部分或填充边缘。工具:Keras:ImageDataGenera</div>
                    </li>
                    <li><a href="/article/1902639752935436288.htm"
                           title="【SoC基础】单片机之寄存器解析" target="_blank">【SoC基础】单片机之寄存器解析</a>
                        <span class="text-muted">望闻问嵌</span>
<a class="tag" taget="_blank" href="/search/%23/1.htm">#</a><a class="tag" taget="_blank" href="/search/SoC/1.htm">SoC</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E7%89%87%E6%9C%BA/1.htm">单片机</a><a class="tag" taget="_blank" href="/search/%E5%B5%8C%E5%85%A5%E5%BC%8F%E7%A1%AC%E4%BB%B6/1.htm">嵌入式硬件</a>
                        <div>:如果你也对机器人、人工智能感兴趣,看来我们志同道合✨:不妨浏览一下我的博客主页【https://blog.csdn.net/weixin_51244852】:文章若有幸对你有帮助,可点赞收藏⭐不迷路:内容若有错误,敬请留言指正!原创文,转载注明出处文章目录1、寄存器位置2、寄存器种类2.1通用用途寄存器2.2CPU执行相关寄存器2.3外设控制寄存器3.寄存器在CPU访问外设过程中起到的作用1、寄</div>
                    </li>
                    <li><a href="/article/1902636857032765440.htm"
                           title="什么时候用到jupyter notebook的NBConvert" target="_blank">什么时候用到jupyter notebook的NBConvert</a>
                        <span class="text-muted">老光私享</span>
<a class="tag" taget="_blank" href="/search/jupyter/1.htm">jupyter</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/windows/1.htm">windows</a><a class="tag" taget="_blank" href="/search/%E6%9C%BA%E5%99%A8%E5%AD%A6%E4%B9%A0/1.htm">机器学习</a>
                        <div>JupyterNotebook的NBConvert功能是用来将JupyterNotebook文件转换为其他格式的工具。通常情况下,我们会用到NBConvert功能来将JupyterNotebook文件转换为HTML、LaTeX、PDF或其他文本格式。这样可以方便地将JupyterNotebook分享给他人,或者将其用于报告、文章、文档或其他写作目的。要使用NBConvert功能,需要在命令行中运行</div>
                    </li>
                    <li><a href="/article/1902636730276704256.htm"
                           title="ASSERT函数" target="_blank">ASSERT函数</a>
                        <span class="text-muted">weixin_34194359</span>
<a class="tag" taget="_blank" href="/search/php/1.htm">php</a>
                        <div>assert宏的原型定义在中,其作用是假设它的条件返回错误,则终止程序运行,原型定义:#includevoidassert(intexpression);assert的作用是现计算表达式expression,假设其值为假(即为0),那么它先向stderr打印一条出错信息,然后通过调用abort来终止程序执行。http://www.chongtang.me/index.php/1419提高程序健壮性</div>
                    </li>
                                <li><a href="/article/108.htm"
                                       title="Nginx负载均衡" target="_blank">Nginx负载均衡</a>
                                    <span class="text-muted">510888780</span>
<a class="tag" taget="_blank" href="/search/nginx/1.htm">nginx</a><a class="tag" taget="_blank" href="/search/%E5%BA%94%E7%94%A8%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">应用服务器</a>
                                    <div>Nginx负载均衡一些基础知识: 
 
nginx 的 upstream目前支持 4 种方式的分配 
1)、轮询(默认) 
      每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。 
2)、weight 
      指定轮询几率,weight和访问比率成正比</div>
                                </li>
                                <li><a href="/article/235.htm"
                                       title="RedHat 6.4 安装 rabbitmq" target="_blank">RedHat 6.4 安装 rabbitmq</a>
                                    <span class="text-muted">bylijinnan</span>
<a class="tag" taget="_blank" href="/search/erlang/1.htm">erlang</a><a class="tag" taget="_blank" href="/search/rabbitmq/1.htm">rabbitmq</a><a class="tag" taget="_blank" href="/search/redhat/1.htm">redhat</a>
                                    <div>在 linux 下安装软件就是折腾,首先是测试机不能上外网要找运维开通,开通后发现测试机的 yum 不能使用于是又要配置 yum 源,最后安装 rabbitmq 时也尝试了两种方法最后才安装成功 
 
机器版本: 
 
[root@redhat1 rabbitmq]# lsb_release
LSB Version:    :base-4.0-amd64:base-4.0-noarch:core</div>
                                </li>
                                <li><a href="/article/362.htm"
                                       title="FilenameUtils工具类" target="_blank">FilenameUtils工具类</a>
                                    <span class="text-muted">eksliang</span>
<a class="tag" taget="_blank" href="/search/FilenameUtils/1.htm">FilenameUtils</a><a class="tag" taget="_blank" href="/search/common-io/1.htm">common-io</a>
                                    <div>转载请出自出处:http://eksliang.iteye.com/blog/2217081 一、概述 
这是一个Java操作文件的常用库,是Apache对java的IO包的封装,这里面有两个非常核心的类FilenameUtils跟FileUtils,其中FilenameUtils是对文件名操作的封装;FileUtils是文件封装,开发中对文件的操作,几乎都可以在这个框架里面找到。 非常的好用。 </div>
                                </li>
                                <li><a href="/article/489.htm"
                                       title="xml文件解析SAX" target="_blank">xml文件解析SAX</a>
                                    <span class="text-muted">不懂事的小屁孩</span>
<a class="tag" taget="_blank" href="/search/xml/1.htm">xml</a>
                                    <div>xml文件解析:xml文件解析有四种方式, 
1.DOM生成和解析XML文档(SAX是基于事件流的解析) 
2.SAX生成和解析XML文档(基于XML文档树结构的解析) 
3.DOM4J生成和解析XML文档 
4.JDOM生成和解析XML  
本文章用第一种方法进行解析,使用android常用的DefaultHandler 
 
 
import org.xml.sax.Attributes;
</div>
                                </li>
                                <li><a href="/article/616.htm"
                                       title="通过定时任务执行mysql的定期删除和新建分区,此处是按日分区" target="_blank">通过定时任务执行mysql的定期删除和新建分区,此处是按日分区</a>
                                    <span class="text-muted">酷的飞上天空</span>
<a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a>
                                    <div>使用python脚本作为命令脚本,linux的定时任务来每天定时执行 
  
#!/usr/bin/python
# -*- coding: utf8 -*-
import pymysql
import datetime
import calendar

#要分区的表
table_name = 'my_table'
#连接数据库的信息
host,user,passwd,db = </div>
                                </li>
                                <li><a href="/article/743.htm"
                                       title="如何搭建数据湖架构?听听专家的意见" target="_blank">如何搭建数据湖架构?听听专家的意见</a>
                                    <span class="text-muted">蓝儿唯美</span>
<a class="tag" taget="_blank" href="/search/%E6%9E%B6%E6%9E%84/1.htm">架构</a>
                                    <div>Edo Interactive在几年前遇到一个大问题:公司使用交易数据来帮助零售商和餐馆进行个性化促销,但其数据仓库没有足够时间去处理所有的信用卡和借记卡交易数据 
 “我们要花费27小时来处理每日的数据量,”Edo主管基础设施和信息系统的高级副总裁Tim Garnto说道:“所以在2013年,我们放弃了现有的基于PostgreSQL的关系型数据库系统,使用了Hadoop集群作为公司的数</div>
                                </li>
                                <li><a href="/article/870.htm"
                                       title="spring学习——控制反转与依赖注入" target="_blank">spring学习——控制反转与依赖注入</a>
                                    <span class="text-muted">a-john</span>
<a class="tag" taget="_blank" href="/search/spring/1.htm">spring</a>
                                    <div>       控制反转(Inversion of Control,英文缩写为IoC)是一个重要的面向对象编程的法则来削减计算机程序的耦合问题,也是轻量级的Spring框架的核心。 控制反转一般分为两种类型,依赖注入(Dependency Injection,简称DI)和依赖查找(Dependency Lookup)。依赖注入应用比较广泛。 
  
</div>
                                </li>
                                <li><a href="/article/997.htm"
                                       title="用spool+unixshell生成文本文件的方法" target="_blank">用spool+unixshell生成文本文件的方法</a>
                                    <span class="text-muted">aijuans</span>
<a class="tag" taget="_blank" href="/search/xshell/1.htm">xshell</a>
                                    <div>例如我们把scott.dept表生成文本文件的语句写成dept.sql,内容如下:  
  set pages 50000; 
  set lines 200; 
  set trims on; 
  set heading off; 
  spool /oracle_backup/log/test/dept.lst; 
  select deptno||','||dname||','||loc </div>
                                </li>
                                <li><a href="/article/1124.htm"
                                       title="1、基础--名词解析(OOA/OOD/OOP)" target="_blank">1、基础--名词解析(OOA/OOD/OOP)</a>
                                    <span class="text-muted">asia007</span>
<a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0%E5%9F%BA%E7%A1%80%E7%9F%A5%E8%AF%86/1.htm">学习基础知识</a>
                                    <div>OOA:Object-Oriented Analysis(面向对象分析方法) 
是在一个系统的开发过程中进行了系统业务调查以后,按照面向对象的思想来分析问题。OOA与结构化分析有较大的区别。OOA所强调的是在系统调查资料的基础上,针对OO方法所需要的素材进行的归类分析和整理,而不是对管理业务现状和方法的分析。 
  OOA(面向对象的分析)模型由5个层次(主题层、对象类层、结构层、属性层和服务层)</div>
                                </li>
                                <li><a href="/article/1251.htm"
                                       title="浅谈java转成json编码格式技术" target="_blank">浅谈java转成json编码格式技术</a>
                                    <span class="text-muted">百合不是茶</span>
<a class="tag" taget="_blank" href="/search/json%E7%BC%96%E7%A0%81/1.htm">json编码</a><a class="tag" taget="_blank" href="/search/java%E8%BD%AC%E6%88%90json%E7%BC%96%E7%A0%81/1.htm">java转成json编码</a>
                                    <div>json编码;是一个轻量级的数据存储和传输的语言 
   
   在java中需要引入json相关的包,引包方式在工程的lib下就可以了 
  
JSON与JAVA数据的转换(JSON 即 JavaScript Object Natation,它是一种轻量级的数据交换格式,非 
  
常适合于服务器与 JavaScript 之间的数据的交</div>
                                </li>
                                <li><a href="/article/1378.htm"
                                       title="web.xml之Spring配置(基于Spring+Struts+Ibatis)" target="_blank">web.xml之Spring配置(基于Spring+Struts+Ibatis)</a>
                                    <span class="text-muted">bijian1013</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/web.xml/1.htm">web.xml</a><a class="tag" taget="_blank" href="/search/SSI/1.htm">SSI</a><a class="tag" taget="_blank" href="/search/spring%E9%85%8D%E7%BD%AE/1.htm">spring配置</a>
                                    <div>指定Spring配置文件位置 
<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>
			/WEB-INF/spring-dao-bean.xml,/WEB-INF/spring-resources.xml,
			/WEB-INF/</div>
                                </li>
                                <li><a href="/article/1505.htm"
                                       title="Installing SonarQube(Fail to download libraries from server)" target="_blank">Installing SonarQube(Fail to download libraries from server)</a>
                                    <span class="text-muted">sunjing</span>
<a class="tag" taget="_blank" href="/search/Install/1.htm">Install</a><a class="tag" taget="_blank" href="/search/Sonar/1.htm">Sonar</a>
                                    <div>1.  Download and unzip the SonarQube distribution  
2.  Starting the Web Server 
The default port is "9000" and the context path is "/". These values can be changed in &l</div>
                                </li>
                                <li><a href="/article/1632.htm"
                                       title="【MongoDB学习笔记十一】Mongo副本集基本的增删查" target="_blank">【MongoDB学习笔记十一】Mongo副本集基本的增删查</a>
                                    <span class="text-muted">bit1129</span>
<a class="tag" taget="_blank" href="/search/mongodb/1.htm">mongodb</a>
                                    <div>一、创建复本集 
  
假设mongod,mongo已经配置在系统路径变量上,启动三个命令行窗口,分别执行如下命令: 
  
mongod --port 27017 --dbpath  data1 --replSet rs0

mongod --port 27018 --dbpath  data2 --replSet rs0

mongod --port 27019 -</div>
                                </li>
                                <li><a href="/article/1759.htm"
                                       title="Anychart图表系列二之执行Flash和HTML5渲染" target="_blank">Anychart图表系列二之执行Flash和HTML5渲染</a>
                                    <span class="text-muted">白糖_</span>
<a class="tag" taget="_blank" href="/search/Flash/1.htm">Flash</a>
                                    <div>今天介绍Anychart的Flash和HTML5渲染功能 
  
 
 HTML5 
 
Anychart从6.0第一个版本起,已经逐渐开始支持各种图的HTML5渲染效果了,也就是说即使你没有安装Flash插件,只要浏览器支持HTML5,也能看到Anychart的图形(不过这些是需要做一些配置的)。 
这里要提醒下大家,Anychart6.0版本对HTML5的支持还不算很成熟,目前还处于</div>
                                </li>
                                <li><a href="/article/1886.htm"
                                       title="Laravel版本更新异常4.2.8-> 4.2.9 Declaration of ... CompilerEngine ... should be compa" target="_blank">Laravel版本更新异常4.2.8-> 4.2.9 Declaration of ... CompilerEngine ... should be compa</a>
                                    <span class="text-muted">bozch</span>
<a class="tag" taget="_blank" href="/search/laravel/1.htm">laravel</a>
                                    <div>昨天在为了把laravel升级到最新的版本,突然之间就出现了如下错误: 
ErrorException thrown with message "Declaration of Illuminate\View\Engines\CompilerEngine::handleViewException() should be compatible with Illuminate\View\Eng</div>
                                </li>
                                <li><a href="/article/2013.htm"
                                       title="编程之美-NIM游戏分析-石头总数为奇数时如何保证先动手者必胜" target="_blank">编程之美-NIM游戏分析-石头总数为奇数时如何保证先动手者必胜</a>
                                    <span class="text-muted">bylijinnan</span>
<a class="tag" taget="_blank" href="/search/%E7%BC%96%E7%A8%8B%E4%B9%8B%E7%BE%8E/1.htm">编程之美</a>
                                    <div>


import java.util.Arrays;
import java.util.Random;

public class Nim {

	/**编程之美 NIM游戏分析
问题:
有N块石头和两个玩家A和B,玩家A先将石头随机分成若干堆,然后按照BABA...的顺序不断轮流取石头,
能将剩下的石头一次取光的玩家获胜,每次取石头时,每个玩家只能从若干堆石头中任选一堆,</div>
                                </li>
                                <li><a href="/article/2140.htm"
                                       title="lunce创建索引及简单查询" target="_blank">lunce创建索引及简单查询</a>
                                    <span class="text-muted">chengxuyuancsdn</span>
<a class="tag" taget="_blank" href="/search/%E6%9F%A5%E8%AF%A2/1.htm">查询</a><a class="tag" taget="_blank" href="/search/%E5%88%9B%E5%BB%BA%E7%B4%A2%E5%BC%95/1.htm">创建索引</a><a class="tag" taget="_blank" href="/search/lunce/1.htm">lunce</a>
                                    <div>import java.io.File;
import java.io.IOException;

import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Docume</div>
                                </li>
                                <li><a href="/article/2267.htm"
                                       title="[IT与投资]坚持独立自主的研究核心技术" target="_blank">[IT与投资]坚持独立自主的研究核心技术</a>
                                    <span class="text-muted">comsci</span>
<a class="tag" taget="_blank" href="/search/it/1.htm">it</a>
                                    <div> 
 
       和别人合作开发某项产品....如果互相之间的技术水平不同,那么这种合作很难进行,一般都会成为强者控制弱者的方法和手段..... 
 
 
       所以弱者,在遇到技术难题的时候,最好不要一开始就去寻求强者的帮助,因为在我们这颗星球上,生物都有一种控制其</div>
                                </li>
                                <li><a href="/article/2394.htm"
                                       title="flashback transaction闪回事务查询" target="_blank">flashback transaction闪回事务查询</a>
                                    <span class="text-muted">daizj</span>
<a class="tag" taget="_blank" href="/search/oracle/1.htm">oracle</a><a class="tag" taget="_blank" href="/search/sql/1.htm">sql</a><a class="tag" taget="_blank" href="/search/%E9%97%AA%E5%9B%9E%E4%BA%8B%E5%8A%A1/1.htm">闪回事务</a>
                                    <div>   
闪回事务查询有别于闪回查询的特点有以下3个: 
 
(1)其正常工作不但需要利用撤销数据,还需要事先启用最小补充日志。 
 
(2)返回的结果不是以前的“旧”数据,而是能够将当前数据修改为以前的样子的撤销SQL(Undo SQL)语句。 
 
(3)集中地在名为flashback_transaction_query表上查询,而不是在各个表上通过“as of”或“vers</div>
                                </li>
                                <li><a href="/article/2521.htm"
                                       title="Java I/O之FilenameFilter类列举出指定路径下某个扩展名的文件" target="_blank">Java I/O之FilenameFilter类列举出指定路径下某个扩展名的文件</a>
                                    <span class="text-muted">游其是你</span>
<a class="tag" taget="_blank" href="/search/FilenameFilter/1.htm">FilenameFilter</a>
                                    <div>这是一个FilenameFilter类用法的例子,实现的列举出“c:\\folder“路径下所有以“.jpg”扩展名的文件。        1   2   3   4   5   6   7   8   9   10   11   12   13   14   15   16   17   18   19   20   21   22   23   24   25   26   27   28  </div>
                                </li>
                                <li><a href="/article/2648.htm"
                                       title="C语言学习五函数,函数的前置声明以及如何在软件开发中合理的设计函数来解决实际问题" target="_blank">C语言学习五函数,函数的前置声明以及如何在软件开发中合理的设计函数来解决实际问题</a>
                                    <span class="text-muted">dcj3sjt126com</span>
<a class="tag" taget="_blank" href="/search/c/1.htm">c</a>
                                    <div># include <stdio.h>

int f(void)		//括号中的void表示该函数不能接受数据,int表示返回的类型为int类型
{
	return 10;	//向主调函数返回10
}

void g(void)	//函数名前面的void表示该函数没有返回值
{
	//return 10;	//error 与第8行行首的void相矛盾
}

in</div>
                                </li>
                                <li><a href="/article/2775.htm"
                                       title="今天在测试环境使用yum安装,遇到一个问题: Error: Cannot retrieve metalink for repository: epel. Pl" target="_blank">今天在测试环境使用yum安装,遇到一个问题: Error: Cannot retrieve metalink for repository: epel. Pl</a>
                                    <span class="text-muted">dcj3sjt126com</span>
<a class="tag" taget="_blank" href="/search/centos/1.htm">centos</a>
                                    <div>今天在测试环境使用yum安装,遇到一个问题: 
Error: Cannot retrieve metalink for repository: epel. Please verify its path and try again 
  
处理很简单,修改文件“/etc/yum.repos.d/epel.repo”, 将baseurl的注释取消, mirrorlist注释掉。即可。 
&n</div>
                                </li>
                                <li><a href="/article/2902.htm"
                                       title="单例模式" target="_blank">单例模式</a>
                                    <span class="text-muted">shuizhaosi888</span>
<a class="tag" taget="_blank" href="/search/%E5%8D%95%E4%BE%8B%E6%A8%A1%E5%BC%8F/1.htm">单例模式</a>
                                    <div>单例模式        懒汉式 
public class RunMain {

	/**
	 * 私有构造
	 */
	private RunMain() {
	}
	
    /**
     * 内部类,用于占位,只有
     */
	private static class SingletonRunMain {
		priv</div>
                                </li>
                                <li><a href="/article/3029.htm"
                                       title="Spring Security(09)——Filter" target="_blank">Spring Security(09)——Filter</a>
                                    <span class="text-muted">234390216</span>
<a class="tag" taget="_blank" href="/search/Spring+Security/1.htm">Spring Security</a>
                                    <div>Filter 
目录 
1.1     Filter顺序 
1.2     添加Filter到FilterChain 
1.3     DelegatingFilterProxy 
1.4     FilterChainProxy 
1.5</div>
                                </li>
                                <li><a href="/article/3156.htm"
                                       title="公司项目NODEJS实践0.1" target="_blank">公司项目NODEJS实践0.1</a>
                                    <span class="text-muted">逐行分析JS源代码</span>
<a class="tag" taget="_blank" href="/search/mongodb/1.htm">mongodb</a><a class="tag" taget="_blank" href="/search/nginx/1.htm">nginx</a><a class="tag" taget="_blank" href="/search/ubuntu/1.htm">ubuntu</a><a class="tag" taget="_blank" href="/search/nodejs/1.htm">nodejs</a>
                                    <div>  
一、前言 
        前端如何独立用nodeJs实现一个简单的注册、登录功能,是不是只用nodejs+sql就可以了?其实是可以实现,但离实际应用还有距离,那要怎么做才是实际可用的。 
        网上有很多nod</div>
                                </li>
                                <li><a href="/article/3283.htm"
                                       title="java.lang.Math" target="_blank">java.lang.Math</a>
                                    <span class="text-muted">liuhaibo_ljf</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/Math/1.htm">Math</a><a class="tag" taget="_blank" href="/search/lang/1.htm">lang</a>
                                    <div>System.out.println(Math.PI); 
System.out.println(Math.abs(1.2)); 
System.out.println(Math.abs(1.2)); 
System.out.println(Math.abs(1)); 
System.out.println(Math.abs(111111111)); 
System.out.println(Mat</div>
                                </li>
                                <li><a href="/article/3410.htm"
                                       title="linux下时间同步" target="_blank">linux下时间同步</a>
                                    <span class="text-muted">nonobaba</span>
<a class="tag" taget="_blank" href="/search/ntp/1.htm">ntp</a>
                                    <div>今天在linux下做hbase集群的时候,发现hmaster启动成功了,但是用hbase命令进入shell的时候报了一个错误  PleaseHoldException: Master is initializing,查看了日志,大致意思是说master和slave时间不同步,没办法,只好找一种手动同步一下,后来发现一共部署了10来台机器,手动同步偏差又比较大,所以还是从网上找现成的解决方</div>
                                </li>
                                <li><a href="/article/3537.htm"
                                       title="ZooKeeper3.4.6的集群部署" target="_blank">ZooKeeper3.4.6的集群部署</a>
                                    <span class="text-muted">roadrunners</span>
<a class="tag" taget="_blank" href="/search/zookeeper/1.htm">zookeeper</a><a class="tag" taget="_blank" href="/search/%E9%9B%86%E7%BE%A4/1.htm">集群</a><a class="tag" taget="_blank" href="/search/%E9%83%A8%E7%BD%B2/1.htm">部署</a>
                                    <div>ZooKeeper是Apache的一个开源项目,在分布式服务中应用比较广泛。它主要用来解决分布式应用中经常遇到的一些数据管理问题,如:统一命名服务、状态同步、集群管理、配置文件管理、同步锁、队列等。这里主要讲集群中ZooKeeper的部署。 
  
1、准备工作 
我们准备3台机器做ZooKeeper集群,分别在3台机器上创建ZooKeeper需要的目录。 
  
数据存储目录</div>
                                </li>
                                <li><a href="/article/3664.htm"
                                       title="Java高效读取大文件" target="_blank">Java高效读取大文件</a>
                                    <span class="text-muted">tomcat_oracle</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a>
                                    <div>  读取文件行的标准方式是在内存中读取,Guava 和Apache Commons IO都提供了如下所示快速读取文件行的方法:     Files.readLines(new File(path), Charsets.UTF_8);     FileUtils.readLines(new File(path));     这种方法带来的问题是文件的所有行都被存放在内存中,当文件足够大时很快就会导致</div>
                                </li>
                                <li><a href="/article/3791.htm"
                                       title="微信支付api返回的xml转换为Map的方法" target="_blank">微信支付api返回的xml转换为Map的方法</a>
                                    <span class="text-muted">xu3508620</span>
<a class="tag" taget="_blank" href="/search/xml/1.htm">xml</a><a class="tag" taget="_blank" href="/search/map/1.htm">map</a><a class="tag" taget="_blank" href="/search/%E5%BE%AE%E4%BF%A1api/1.htm">微信api</a>
                                    <div>举例如下: 
<xml> 
   <return_code><![CDATA[SUCCESS]]></return_code> 
   <return_msg><![CDATA[OK]]></return_msg> 
   <appid><</div>
                                </li>
                </ul>
            </div>
        </div>
    </div>

<div>
    <div class="container">
        <div class="indexes">
            <strong>按字母分类:</strong>
            <a href="/tags/A/1.htm" target="_blank">A</a><a href="/tags/B/1.htm" target="_blank">B</a><a href="/tags/C/1.htm" target="_blank">C</a><a
                href="/tags/D/1.htm" target="_blank">D</a><a href="/tags/E/1.htm" target="_blank">E</a><a href="/tags/F/1.htm" target="_blank">F</a><a
                href="/tags/G/1.htm" target="_blank">G</a><a href="/tags/H/1.htm" target="_blank">H</a><a href="/tags/I/1.htm" target="_blank">I</a><a
                href="/tags/J/1.htm" target="_blank">J</a><a href="/tags/K/1.htm" target="_blank">K</a><a href="/tags/L/1.htm" target="_blank">L</a><a
                href="/tags/M/1.htm" target="_blank">M</a><a href="/tags/N/1.htm" target="_blank">N</a><a href="/tags/O/1.htm" target="_blank">O</a><a
                href="/tags/P/1.htm" target="_blank">P</a><a href="/tags/Q/1.htm" target="_blank">Q</a><a href="/tags/R/1.htm" target="_blank">R</a><a
                href="/tags/S/1.htm" target="_blank">S</a><a href="/tags/T/1.htm" target="_blank">T</a><a href="/tags/U/1.htm" target="_blank">U</a><a
                href="/tags/V/1.htm" target="_blank">V</a><a href="/tags/W/1.htm" target="_blank">W</a><a href="/tags/X/1.htm" target="_blank">X</a><a
                href="/tags/Y/1.htm" target="_blank">Y</a><a href="/tags/Z/1.htm" target="_blank">Z</a><a href="/tags/0/1.htm" target="_blank">其他</a>
        </div>
    </div>
</div>
<footer id="footer" class="mb30 mt30">
    <div class="container">
        <div class="footBglm">
            <a target="_blank" href="/">首页</a> -
            <a target="_blank" href="/custom/about.htm">关于我们</a> -
            <a target="_blank" href="/search/Java/1.htm">站内搜索</a> -
            <a target="_blank" href="/sitemap.txt">Sitemap</a> -
            <a target="_blank" href="/custom/delete.htm">侵权投诉</a>
        </div>
        <div class="copyright">版权所有 IT知识库 CopyRight © 2000-2050 E-COM-NET.COM , All Rights Reserved.
<!--            <a href="https://beian.miit.gov.cn/" rel="nofollow" target="_blank">京ICP备09083238号</a><br>-->
        </div>
    </div>
</footer>
<!-- 代码高亮 -->
<script type="text/javascript" src="/static/syntaxhighlighter/scripts/shCore.js"></script>
<script type="text/javascript" src="/static/syntaxhighlighter/scripts/shLegacy.js"></script>
<script type="text/javascript" src="/static/syntaxhighlighter/scripts/shAutoloader.js"></script>
<link type="text/css" rel="stylesheet" href="/static/syntaxhighlighter/styles/shCoreDefault.css"/>
<script type="text/javascript" src="/static/syntaxhighlighter/src/my_start_1.js"></script>





</body>

</html>