jasperReport+iReport的使用

阅读更多

转载自http://lanyan-lan.iteye.com/blog/424903

(1) 
JasperReports是一个开源的java报表制作引擎 
iReport是JasperReports的一个GUI工具,用来生成JasperReports的jrxml文件。 
JasperReports的报表是用XML文件来定义的,约定用jrxml作后缀名。一个典型的jrxml文件包含以下元素: 
    * - 根元素 
    * - 报表的标题,一篇报表里只在开头打印一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <pageHeader> - 页眉,报表每页开头打印一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <detail> - 报表正文<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <pageFooter> - 页脚,报表每页末尾打印一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">    * <band> - 定义报表部件,以上所有元素都包含一个band元素作为他们唯一的子元素<span class="Apple-converted-space"> </span></span><br style=""><span style="">  ·Summary:可能需要对几页(你的报表可能有几个页组成)的统计值。比如50个销售记录共占用了3页,那么放置这些统计记录的统计值最好的地方就是summary。<span class="Apple-converted-space"> </span></span><br style=""><span style="">  ·groupHeader:每个表的内容可能需要根据某个属性进行划分显示内容和计算内容,比如希望以月份为单位每组分开显示销售记录,那么就可以定义一个组(组的定义参考后文),groupHeader就是放置组说明或是组标志最好的地方。<span class="Apple-converted-space"> </span></span><br style=""><span style="">  ·Groupfooter:放置组的统计或是说明<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">各元素分析:<span class="Apple-converted-space"> </span></span><br style=""><span style="">static text:静态文本,只是用来在报表中显示;<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P--->表示是参数;<span class="Apple-converted-space"> </span></span><br style=""><span style="">如:"20"+$P{statement_current_date}<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">$F--->表示是textfield变量.<span class="Apple-converted-space"> </span></span><br style=""><span style="">如:$F{account_code}<span class="Apple-converted-space"> </span></span><br style=""><span style="">此变量是在<field name>中定义的.其值是在<queryString>中,通过select数据库后,得到的.<span class="Apple-converted-space"> </span></span><br style=""><span style="">select的列名 = field name<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">$V--->表示一个变量<span class="Apple-converted-space"> </span></span><br style=""><span style="">如:$V{balance}<span class="Apple-converted-space"> </span></span><br style=""><span style="">变量的默认值是在报表中设置的.一般设置为0.其真正的值是通过 $P或$F来获得的.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(3)<span class="Apple-converted-space"> </span></span><br style=""><span style="">A,报表中的QueryString语句,可以通过界面上的DataBase中的Report SQL Query来进行添加-->会自动生成相应的TextField.若不行,则可自动手动添加.<span class="Apple-converted-space"> </span></span><br style=""><span style="">B,如果要直接修改代码,可以选择界面上的'编辑'-->'直接编辑XML Source'-->先进行保存-->就会出现代码界面.<span class="Apple-converted-space"> </span></span><br style=""><span style="">C,如果要修改JASPER REPORT的属性,可以选择界面上的'预览'-->'报表属性'<span class="Apple-converted-space"> </span></span><br style=""><span style="">E,添加group,可以通过点击界面上的相应'group'按钮来添加.<span class="Apple-converted-space"> </span></span><br style=""><span style="">F,隐藏不要的区域,要设bank=0,而不能删除为空.删除为空,则为默认值<span class="Apple-converted-space"> </span></span><br style=""><span style="">G,IReport中的左栏中的各元素的后面的[X,Y]内的数据,是指此元素偏离'左上角'的X,Y距离.<span class="Apple-converted-space"> </span></span><br style=""><span style="">H,设置子报表时,要将子报表的属性中的"上边界,下边界,左边界,右边界"全部设置为0,否则会出现子报表传回来的数据,在主报表中没法对齐的现象.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(4)<span class="Apple-converted-space"> </span></span><br style=""><span style="">当没有数据(是指QueryString语句SELECT出来的数据为NULL)时,设置怎样显示:<span class="Apple-converted-space"> </span></span><br style=""><span style="">相关代码:<span class="Apple-converted-space"> </span></span><br style=""><span style="">whenNoDataType="NoPages / BlankPage / AllSectionsNoDetail"<span class="Apple-converted-space"> </span></span><br style=""><span style="">NoPages:当没数据时,会弹出一个对话框提示你没数据,然后显示一个没激活的框.<span class="Apple-converted-space"> </span></span><br style=""><span style="">BlankPage :不会提示,只是显示一个白纸.<span class="Apple-converted-space"> </span></span><br style=""><span style="">AllSectionsNoDetail:不会提示,但那些静态的文本,以及从上一层或JAVA文件中传来显示的参数,都可以显示.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(5)<span class="Apple-converted-space"> </span></span><br style=""><span style="">内置的报表变量:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$V{PAGE_NUMBER}:(常用)<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量保存当前的页号,在报表装填结束的时候,这个变量就保存着最终文档的总页数。所以要在JasperReport的文本字段中显示页号和总页数你都可以用它。<span class="Apple-converted-space"> </span></span><br style=""><span style="">A,<span class="Apple-converted-space"> </span></span><br style=""><span style="">只需要添加一个系统的变量:$V{PAGE_NUMBER};<span class="Apple-converted-space"> </span></span><br style=""><span style="">对于$V{PAGE_NUMBER}:当evaluationTime="Now"时,即是计算当页所在哪一页.   (now:即时执行此表达式.)<span class="Apple-converted-space"> </span></span><br style=""><span style="">                    当evaluationTime="Report"时,即是计算当页所在哪一页.(Report:整个报表执行完后才执行此表达式)<span class="Apple-converted-space"> </span></span><br style=""><span style="">B,<span class="Apple-converted-space"> </span></span><br style=""><span style="">并将其转换为String的类型.<span class="Apple-converted-space"> </span></span><br style=""><span style="">C,总体代码:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><textField evaluationTime="Now"><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <textFieldExpression class="java.lang.String"><span class="Apple-converted-space"> </span></span><br style=""><span style="">"Page " + String.valueOf($V{PAGE_NUMBER}) + "   Of"<span class="Apple-converted-space"> </span></span><br style=""><span style="">  </textFieldExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></textField><span class="Apple-converted-space"> </span></span><br style=""><span style=""><textField evaluationTime="Report"><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <textFieldExpression class="java.lang.String"><span class="Apple-converted-space"> </span></span><br style=""><span style="">String.valueOf($V{PAGE_NUMBER})<span class="Apple-converted-space"> </span></span><br style=""><span style="">  </textFieldExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></textField><span class="Apple-converted-space"> </span></span><br style=""><span style="">$V{REPORT_COUNT}:<span class="Apple-converted-space"> </span></span><br style=""><span style="">当evaluationTime=Report时,将记录报表的总记录数.<span class="Apple-converted-space"> </span></span><br style=""><span style="">当evaluationTime=Column时,将记录报表从开始到当前页的总记录数.<span class="Apple-converted-space"> </span></span><br style=""><span style="">Variable COLUMN_NUMBER<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量将记录当前的列号。<span class="Apple-converted-space"> </span></span><br style=""><span style="">Variable PAGE_COUNT<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量纪录当前页中处理的record的数目。<span class="Apple-converted-space"> </span></span><br style=""><span style="">Variable COLUMN_COUNT<span class="Apple-converted-space"> </span></span><br style=""><span style="">这个变量纪录生成当前列时所处理的record的数目。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(6)<span class="Apple-converted-space"> </span></span><br style=""><span style="">field的动态显示+动态显示不同的格式:<span class="Apple-converted-space"> </span></span><br style=""><span style="">有些报表可能需要对同种类型的数据根据重要性不同而显示不同的风格。例如,要在订单列表中加亮显示金额超过100$的订单.<span class="Apple-converted-space"> </span></span><br style=""><span style="">而文本域的现实格式不能动态改变,我们如何实现这种功能呢?<span class="Apple-converted-space"> </span></span><br style=""><span style="">解决办法是:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在同样的位置放两个文本域来显示相同的内容,但是设置不同的显示格式,一个正常显示,一个加粗并加亮显示红色,同时还要为他们设定<printWhenExpression>元素,让他们可以根据条件表达式来切换。这里的表达式就是$F{value} < 100(正常显示的文本域)和$F{value} >= 100(加亮显示的文本域)。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(7)<span class="Apple-converted-space"> </span></span><br style=""><span style="">创建子报表<span class="Apple-converted-space"> </span></span><br style=""><span style="">1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在代码中,将子报表以参数形式加载:<span class="Apple-converted-space"> </span></span><br style=""><span style="">JasperReport sixUnitPrice = (JasperReport)JRLoader.loadObject("jasper/TrendAve_ItemIntel_6MonthUnitPrice.jasper");<span class="Apple-converted-space"> </span></span><br style=""><span style="">parameters.put("sixUnitPrice", sixUnitPrice);<span class="Apple-converted-space"> </span></span><br style=""><span style="">2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中,创建上面的相应参数sixUnitPrice. 其类型为:net.sf.jasperreports.engine.JasperReport<span class="Apple-converted-space"> </span></span><br style=""><span style="">3)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在iReprot中添加,划拉出一块子报表.<span class="Apple-converted-space"> </span></span><br style=""><span style="">在subReport项中,选中:' use connection expression '<span class="Apple-converted-space"> </span></span><br style=""><span style="">在subReport other项中:<span class="Apple-converted-space"> </span></span><br style=""><span style="">设置image expression class=net.sf.jasperreports.engine.JasperReport<span class="Apple-converted-space"> </span></span><br style=""><span style="">设置subreport expression中填写代码中的相应参数:$P{sixUnitPrice}<span class="Apple-converted-space"> </span></span><br style=""><span style="">4)<span class="Apple-converted-space"> </span></span><br style=""><span style="">设置要传到子报表的参数,并在主报表中创建相应的参数.<span class="Apple-converted-space"> </span></span><br style=""><span style="">5)<span class="Apple-converted-space"> </span></span><br style=""><span style="">新建子报表,创建一参数(与主报表传递的参数一样),来接收从主报表传来的参数.-->即可应用了.<span class="Apple-converted-space"> </span></span><br style=""><span style="">说明:<span class="Apple-converted-space"> </span></span><br style=""><span style="">位于多层之下的子报表,也需要从主报表开始时,就可以加载,传递下去,否则加载不了.因为一开始,都是从JAVA文件中从传过来,然后一层层传下去的.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(8)<span class="Apple-converted-space"> </span></span><br style=""><span style="">hashmap参数在报表间传递值的用法<span class="Apple-converted-space"> </span></span><br style=""><span style="">1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">如何带参数:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在某层子报表中创建一个新的子报表,此新子报表,必须从:报表java类中定义-->主报表-->各上级父报表中对此新子报表进行定义(定义此参数+各父报表添加此新报表参数,以便其子报表可以获得)-->目的子报表<span class="Apple-converted-space"> </span></span><br style=""><span style="">2)hashmap参数在报表间传递值的用法<span class="Apple-converted-space"> </span></span><br style=""><span style="">如上的专题记录,$P{group_total_hash}此参数是一个hashmap,从其定义是在子报表中的,最终用:是在主报表中,作为统计数据.<span class="Apple-converted-space"> </span></span><br style=""><span style="">怎样用:<span class="Apple-converted-space"> </span></span><br style=""><span style="">1.<span class="Apple-converted-space"> </span></span><br style=""><span style="">先在主报表,以及子报表中都要定义hashmap,并在子报表的各上层报表进行赋值,使参数可以主报表与子报表中间进行传递:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><parameter name="group_total_hash" isForPrompting="false" class="java.util.HashMap"><span class="Apple-converted-space"> </span></span><br style=""><span style=""><defaultValueExpression ><![CDATA[new java.util.HashMap()]></defaultValueExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></parameter><span class="Apple-converted-space"> </span></span><br style=""><span style="">2.<span class="Apple-converted-space"> </span></span><br style=""><span style="">在子报表中,在区间的显示属性中添加:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{group_total_hash}.put();如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{trayout_hash}.put("trayout",$F{totalqty}) == null?<span class="Apple-converted-space"> </span></span><br style=""><span style="">Boolean.TRUE:Boolean.TRUE<span class="Apple-converted-space"> </span></span><br style=""><span style="">3.<span class="Apple-converted-space"> </span></span><br style=""><span style="">/*<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中:<span class="Apple-converted-space"> </span></span><br style=""><span style="">子报表的返回值有一个问题:它们是在当前区域的所有元素都被处理之后才返回的。<span class="Apple-converted-space"> </span></span><br style=""><span style="">所以,为了能在主报表中的子报表所在的同一区域显示返回值,我们必须延迟文本域表达式的处理时机。这是通过加入一个无效的分组让表达式在分组结束时处理来实现的,而这个无效分组的效果就是数据源中的每条记录就是一组,而且它自己没有组头和组尾区域。<span class="Apple-converted-space"> </span></span><br style=""><span style="">*/<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中:<span class="Apple-converted-space"> </span></span><br style=""><span style="">添加一Field,设置数据类型为Double,且Evaluation time=Column(否则数据出不来)<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{group_total_hash}.get();如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">new Double<span class="Apple-converted-space"> </span></span><br style=""><span style="">(<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">  -<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayin_hash}.get("trayin")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">)<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.<span class="Apple-converted-space"> </span></span><br style=""><span style="">具体可以参考ACCOUNT中的PL报表,或SCM中的item intelligence报表中的设置及用法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">主报表:<span class="Apple-converted-space"> </span></span><br style=""><span style="">ProfitLoss_basic.jrxml<span class="Apple-converted-space"> </span></span><br style=""><span style="">用于计算各部分total的子报表:<span class="Apple-converted-space"> </span></span><br style=""><span style="">ProfitLoss_basic_subReport_profit_loss_total_year_list.jrxml<span class="Apple-converted-space"> </span></span><br style=""><span style="">或<span class="Apple-converted-space"> </span></span><br style=""><span style="">TrendAve_ItemIntelReport.jrxml<span class="Apple-converted-space"> </span></span><br style=""><span style="">TrendAve_ItemIntel_trayout.jrxml.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(9)<span class="Apple-converted-space"> </span></span><br style=""><span style="">Group的用法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">用法一:(分类显示及计算)<span class="Apple-converted-space"> </span></span><br style=""><span style="">假设有两表:<span class="Apple-converted-space"> </span></span><br style=""><span style="">mysql> select * from A;<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">| id   | name |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    1 | hk   |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    2 | hk   |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">mysql> select * from B;<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+------+-------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">| id   | Aid  | name | value |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+------+-------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    1 |    1 | sz   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    1 |    1 | cz   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    2 |    2 | zh   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">|    2 |    2 | gz   |     1 |<span class="Apple-converted-space"> </span></span><br style=""><span style="">+------+------+------+-------+<span class="Apple-converted-space"> </span></span><br style=""><span style="">报表要分两层,第一层循环查询A表,第二层(即子报表)循环查询B表在属于A表的记录.<span class="Apple-converted-space"> </span></span><br style=""><span style="">若不用group,则会出现(-->后面是各组件中iReport中的位置):<span class="Apple-converted-space"> </span></span><br style=""><span style="">ID    Name  value  -->放于报表中的pageHeader<span class="Apple-converted-space"> </span></span><br style=""><span style="">1     hk     1     -->放于第一层报表中的detail -->循环每一条记录且显示<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   sz     1     -->放于第二层报表中的detail<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   cz     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">2     hk     1     //name与上相同<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   zh     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   gz     1<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">若采用group按照name进行分组,则jasper会把name相同的放入一组,只显示一次.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">采用name分组后的效果:<span class="Apple-converted-space"> </span></span><br style=""><span style="">ID    Name  value  -->放于报表中的pageHeader<span class="Apple-converted-space"> </span></span><br style=""><span style="">1     hk     1     -->放于第一层报表中groupHeader,将所有相同的name集合在一起,只显示一次<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   sz     1     -->放于第二层报表中的detail<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   cz     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  1   zh     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  2   gz     1<span class="Apple-converted-space"> </span></span><br style=""><span style="">  sum value: 5     -->放于第一层报表中groupFooter<span class="Apple-converted-space"> </span></span><br style=""><span style="">补充说明:<span class="Apple-converted-space"> </span></span><br style=""><span style="">对于上面的group,须先点击"group"按钮进行定义(如:nameGroup).<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">同时,可以以group的基准进行计算(结合变量variable),放于groupFooter.<span class="Apple-converted-space"> </span></span><br style=""><span style="">(1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在iRport中,新建变量sumValue,定义如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">variable type: Double<span class="Apple-converted-space"> </span></span><br style=""><span style="">caculation type: sum<span class="Apple-converted-space"> </span></span><br style=""><span style="">Reset type: Group<span class="Apple-converted-space"> </span></span><br style=""><span style="">Reset Group: 上面自定义的group名(如:nameGroup)<span class="Apple-converted-space"> </span></span><br style=""><span style="">variable expression:(即进行计算的表达式) $F{value}<span class="Apple-converted-space"> </span></span><br style=""><span style="">(2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在groupFooter添加一field:<span class="Apple-converted-space"> </span></span><br style=""><span style="">须定义:<span class="Apple-converted-space"> </span></span><br style=""><span style="">Evaluation time : group,而不是now<span class="Apple-converted-space"> </span></span><br style=""><span style="">Evaluation Group: 上面自定义的group名(如:nameGroup)<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">jasper报表,子报表内容显示重叠<span class="Apple-converted-space"> </span></span><br style=""><span style="">在jasper中,若在detail区域中,把两个一模一样的子报表上下放置.则在循环输出时,会出现上下子报表<span class="Apple-converted-space"> </span></span><br style=""><span style="">输出内容相遮掩的结果.<span class="Apple-converted-space"> </span></span><br style=""><span style="">解决方案:用group分离显示.<span class="Apple-converted-space"> </span></span><br style=""><span style="">把两个子报表,分别放于两个不同的group中,分组条件为主报表的每一个ID,这样,主报表循环显示时,就<span class="Apple-converted-space"> </span></span><br style=""><span style="">会将各分组一一显示出来,不会影响其显示.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">用法二:<span class="Apple-converted-space"> </span></span><br style=""><span style="">利用group来进行分组和实现子报表返回值:<span class="Apple-converted-space"> </span></span><br style=""><span style="">第(8)点的返回值,只适合于非循环性的.<span class="Apple-converted-space"> </span></span><br style=""><span style="">若在主报表的detail区域,需要让每条record都将子报表返回值到对应的record中,则要采用这种方法.上面的方法实现不了.<span class="Apple-converted-space"> </span></span><br style=""><span style="">因为子报表的返回值有一个问题:它们是在当前区域的所有元素都被处理之后才返回的。如果你想在子报表所在的主报表区域显示它的返回值,你最终将看到它们返回的太晚了。<span class="Apple-converted-space"> </span></span><br style=""><span style="">具体实现方法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">1)<span class="Apple-converted-space"> </span></span><br style=""><span style="">先在主报表,子报表建立一个同名的hashmap容器,且将主报表的这个参数作为子报表的传递参数,传到<span class="Apple-converted-space"> </span></span><br style=""><span style="">子报表中.<span class="Apple-converted-space"> </span></span><br style=""><span style="">2)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在报表中,对窗口进行加值:<span class="Apple-converted-space"> </span></span><br style=""><span style="">方式一:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在子报表中,在summary区域的属性中添加:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{trayout_hash}.put("trayout",$F{totalqty}) == null?Boolean.TRUE:Boolean.TRUE<span class="Apple-converted-space"> </span></span><br style=""><span style="">方式二:<span class="Apple-converted-space"> </span></span><br style=""><span style="">在子报表中,在summary区域中添加一个不可见的直线元素,且在其中设置:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><line><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <reportElement x="0" y="0" width="0" height="0"><span class="Apple-converted-space"> </span></span><br style=""><span style="">    <printWhenExpression><span class="Apple-converted-space"> </span></span><br style=""><span style="">      $P{trayout_hash}.put("trayout",$F{totalqty}) == null?Boolean.FALSE:Boolean.FALSE<span class="Apple-converted-space"> </span></span><br style=""><span style="">    </printWhenExpression><span class="Apple-converted-space"> </span></span><br style=""><span style="">  </reportElement><span class="Apple-converted-space"> </span></span><br style=""><span style=""></line><span class="Apple-converted-space"> </span></span><br style=""><span style="">3)<span class="Apple-converted-space"> </span></span><br style=""><span style="">在主报表中,添加一个分组,以每条记录作为一个分组.操作如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">A,点击GROUP按钮.<span class="Apple-converted-space"> </span></span><br style=""><span style="">B,填写组名;<span class="Apple-converted-space"> </span></span><br style=""><span style="">C,分组表达式: $F{item_code}.(也可以id作为分组) -->分组的关键所在<span class="Apple-converted-space"> </span></span><br style=""><span style="">D,选择:是否start on a new page -->让最后所得的分组,是否以分页的形式显示.<span class="Apple-converted-space"> </span></span><br style=""><span style="">4)<span class="Apple-converted-space"> </span></span><br style=""><span style="">对于detail区域中,要返回值的field,这样设置:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><textField evaluationTime="Group" evaluationGroup="itemcodeGroup"><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <reportElement x="335" y="50" width="175" height="15"/><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <textFieldExpression ><span class="Apple-converted-space"> </span></span><br style=""><span style="">    $P{trayout_hash}.get("trayout")<span class="Apple-converted-space"> </span></span><br style=""><span style="">  </textFieldExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></textField><span class="Apple-converted-space"> </span></span><br style=""><span style="">采用Group实现返回值的说明:<span class="Apple-converted-space"> </span></span><br style=""><span style="">子报表的返回值有一个问题:它们是在当前区域的所有元素都被处理之后才返回的。如果你想在子报<span class="Apple-converted-space"> </span></span><br style=""><span style="">表所在的主报表区域显示它的返回值,你最终将看到它们返回的太晚了。<span class="Apple-converted-space"> </span></span><br style=""><span style="">所以,为了能在主报表中的子报表所在的同一区域显示返回值,我们必须延迟文本域表达式的处理时<span class="Apple-converted-space"> </span></span><br style=""><span style="">机。这是通过加入一个无效的分组让表达式在分组结束时处理来实现的,而这个无效分组的效果就是<span class="Apple-converted-space"> </span></span><br style=""><span style="">数据源中的每条记录就是一组,而且它自己没有组头和组尾区域。<span class="Apple-converted-space"> </span></span><br style=""><span style=""><group ><span class="Apple-converted-space"> </span></span><br style=""><span style="">  <groupExpression>$F{item_code}</groupExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></group><span class="Apple-converted-space"> </span></span><br style=""><br style=""><br style=""><span style="">(10)<span class="Apple-converted-space"> </span></span><br style=""><span style="">若数据类型设置为Double,则须:<span class="Apple-converted-space"> </span></span><br style=""><span style="">$P{trayout_hash}.get("trayout")-->Object类型;<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout"))-->转换成Double类型;<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout")).doubleValue()-->转换成double类型,进行计算;<span class="Apple-converted-space"> </span></span><br style=""><span style="">new Doubel(A-B)--->将最终结果转换成Double,因为上面设置类型类型时,用了Double.<span class="Apple-converted-space"> </span></span><br style=""><span style="">如下:<span class="Apple-converted-space"> </span></span><br style=""><span style="">new Double<span class="Apple-converted-space"> </span></span><br style=""><span style="">(<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayout_hash}.get("trayout")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">  -<span class="Apple-converted-space"> </span></span><br style=""><span style="">((Double)$P{trayin_hash}.get("trayin")).doubleValue()<span class="Apple-converted-space"> </span></span><br style=""><span style="">)<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(11)<span class="Apple-converted-space"> </span></span><br style=""><span style="">变量还可以声明来完成引擎内建计算的求值,如:count、sum、average、lowest、highest、 variance等等。一个完成Quantity字段sum计算的变量定义如下:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><variable name="QuantitySum"<span class="Apple-converted-space"> </span></span><br style=""><span style="">class="java.lang.Double" calculation="Sum"><span class="Apple-converted-space"> </span></span><br style=""><span style=""><variableExpression>$F{Quantity}</variableExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></variable><span class="Apple-converted-space"> </span></span><br style=""><span style="">我们还可以通过制定初始化级别来改变计算过程,默认的级别是Report就是变量仅在报表开始处初 始化一次,一直到报表结束完成计算。<span class="Apple-converted-space"> </span></span><br style=""><span style="">我们可以选择更低的级别让变量在每个Page、Column或者Group级别重新初始化。假如我们想计算 计算每页的总数,变量声明如下:<span class="Apple-converted-space"> </span></span><br style=""><span style=""><variable name="QuantitySum" class="java.lang.Double"<span class="Apple-converted-space"> </span></span><br style=""><span style="">resetType="Page" calculation="Sum"><span class="Apple-converted-space"> </span></span><br style=""><span style=""><variableExpression>$F{Quantity}</variableExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""><initialValueExpression>new Double(0) </initialValueExpression><span class="Apple-converted-space"> </span></span><br style=""><span style=""></variable><span class="Apple-converted-space"> </span></span><br style=""><span style="">变量将在每一页的开始处被初始化为0。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(12)<span class="Apple-converted-space"> </span></span><br style=""><span style="">变量的resetType解释:<span class="Apple-converted-space"> </span></span><br style=""><span style="">报表变量的值可以在每一次迭代(iteration)中被改变,但也可以在装填过程中的某一特定的时间(specified moments)通过它的初始的value表达式恢复其初始值。这一行为是由resetType属性控制的,这一属性规定了报表装填过程中当报表变量在何时需要重新进行初始化(或恢复到初始值)。该元素有五种选项值:<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.1<span class="Apple-converted-space"> </span></span><br style=""><span style="">No Reset:变量将不会使用其initial value expression对自身进行初始化,而将仅报表从变量表达式中所求得的值(resetType=”None”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.2<span class="Apple-converted-space"> </span></span><br style=""><span style="">Report Level Reset:变量将在报表填充过程的起始阶段使用其初始化表达式初始化一次(resetType=”Report”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">缺省的属性为resetType=”Report”<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.3<span class="Apple-converted-space"> </span></span><br style=""><span style="">Page Level Reset:变量将在每一页的起始时被重新初始化(resetType=”Page”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.4<span class="Apple-converted-space"> </span></span><br style=""><span style="">Colunm Level Reset:变量将在每个新列的开始被初始化(resetType=”Column”)<span class="Apple-converted-space"> </span></span><br style=""><span style="">4.5<span class="Apple-converted-space"> </span></span><br style=""><span style="">Group Level Reset:变量将在每次resetGroup属性提供的break的地方被重新初始化(resetType=”Group”)。<span class="Apple-converted-space"> </span></span><br style=""><span style="">Reset Group<span class="Apple-converted-space"> </span></span><br style=""><span style="">如果存在的话,resetGroup属性包含了报表的组的名字并且仅与resetType=”Gropu”的resetType属性相关联。<span class="Apple-converted-space"> </span></span><br style=""><br style=""><span style="">(13)<span class="Apple-converted-space"> </span></span><br style=""><span style="">报表的分层显示方法:<span class="Apple-converted-space"> </span></span><br style=""><span style="">外层,在主报表中查询循环显示;<span class="Apple-converted-space"> </span></span><br style=""><span style="">下层,在子报表中查询循环显示.<span class="Apple-converted-space"> </span></span><br style=""><br style=""><br style=""></p> </div> </div> </div> </div> </div> <!--PC和WAP自适应版--> <div id="SOHUCS" sid="1176554590452133888"></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">你可能感兴趣的:(jasperReport+iReport的使用)</h4> <div id="paradigm-article-related"> <div class="recommend-post mb30"> <ul class="widget-links"> <li><a href="/article/1835512920797179904.htm" title="element实现动态路由+面包屑" target="_blank">element实现动态路由+面包屑</a> <span class="text-muted">软件技术NINI</span> <a class="tag" taget="_blank" href="/search/vue%E6%A1%88%E4%BE%8B/1.htm">vue案例</a><a class="tag" taget="_blank" href="/search/vue.js/1.htm">vue.js</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a> <div>el-breadcrumb是ElementUI组件库中的一个面包屑导航组件,它用于显示当前页面的路径,帮助用户快速理解和导航到应用的各个部分。在Vue.js项目中,如果你已经安装了ElementUI,就可以很方便地使用el-breadcrumb组件。以下是一个基本的使用示例:安装ElementUI(如果你还没有安装的话):你可以通过npm或yarn来安装ElementUI。bash复制代码npmi</div> </li> <li><a href="/article/1835505606245576704.htm" title="Python中os.environ基本介绍及使用方法" target="_blank">Python中os.environ基本介绍及使用方法</a> <span class="text-muted">鹤冲天Pro</span> <a class="tag" taget="_blank" href="/search/%23/1.htm">#</a><a class="tag" taget="_blank" href="/search/Python/1.htm">Python</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</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%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>文章目录python中os.environos.environ简介os.environ进行环境变量的增删改查python中os.environ的使用详解1.简介2.key字段详解2.1常见key字段3.os.environ.get()用法4.环境变量的增删改查和判断是否存在4.1新增环境变量4.2更新环境变量4.3获取环境变量4.4删除环境变量4.5判断环境变量是否存在python中os.envi</div> </li> <li><a href="/article/1835503712899002368.htm" title="linux中sdl的使用教程,sdl使用入门" target="_blank">linux中sdl的使用教程,sdl使用入门</a> <span class="text-muted">Melissa Corvinus</span> <a class="tag" taget="_blank" href="/search/linux%E4%B8%ADsdl%E7%9A%84%E4%BD%BF%E7%94%A8%E6%95%99%E7%A8%8B/1.htm">linux中sdl的使用教程</a> <div>本文通过一个简单示例讲解SDL的基本使用流程。示例中展示一个窗口,窗口里面有个随机颜色快随机移动。当我们鼠标点击关闭按钮时间窗口关闭。基本步骤如下:1.初始化SDL并创建一个窗口。SDL_Init()初始化SDL_CreateWindow()创建窗口2.纹理渲染存储RGB和存储纹理的区别:比如一个从左到右由红色渐变到蓝色的矩形,用存储RGB的话就需要把矩形中每个点的具体颜色值存储下来;而纹理只是一</div> </li> <li><a href="/article/1835500751997202432.htm" title="直返最高等级与直返APP:无需邀请码的返利新体验" target="_blank">直返最高等级与直返APP:无需邀请码的返利新体验</a> <span class="text-muted">古楼</span> <div>随着互联网的普及和电商的兴起,直返模式逐渐成为一种流行的商业模式。在这种模式下,消费者通过购买产品或服务,获得一定的返利,并可以分享给更多的人。其中,直返最高等级和直返APP是直返模式中的重要概念和工具。本文将详细介绍直返最高等级的概念、直返APP的使用以及与邀请码的关系。【高省】APP(高佣金领导者)是一个自用省钱佣金高,分享推广赚钱多的平台,百度有几百万篇报道,运行三年,稳定可靠。高省APP,</div> </li> <li><a href="/article/1835498218293653504.htm" title="2020-04-12每天三百字之连接与替代" target="_blank">2020-04-12每天三百字之连接与替代</a> <span class="text-muted">冷眼看潮</span> <div>不知道是不是好为人师,有时候还真想和别人分享一下我对某些现象的看法或者解释。人类社会不断发展进步的过程,就是不断连接与替代的过程。人类发现了火并应用火以后,告别了茹毛饮血的野兽般的原始生活(火烧、烹饪替代了生食)人类用石器代替了完全手工,工具的使用使人类进步一大步。类似这样的替代还有很多,随着科技的发展,有更多的原始的事物被替代,代之以更高效、更先进的技术。在近现代,汽车替代了马车,高速公路和铁路</div> </li> <li><a href="/article/1835492869062881280.htm" title="pyecharts——绘制柱形图折线图" target="_blank">pyecharts——绘制柱形图折线图</a> <span class="text-muted">2224070247</span> <a class="tag" taget="_blank" href="/search/%E4%BF%A1%E6%81%AF%E5%8F%AF%E8%A7%86%E5%8C%96/1.htm">信息可视化</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><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%8F%AF%E8%A7%86%E5%8C%96/1.htm">数据可视化</a> <div>一、pyecharts概述自2013年6月百度EFE(ExcellentFrontEnd)数据可视化团队研发的ECharts1.0发布到GitHub网站以来,ECharts一直备受业界权威的关注并获得广泛好评,成为目前成熟且流行的数据可视化图表工具,被应用到诸多数据可视化的开发领域。Python作为数据分析领域最受欢迎的语言,也加入ECharts的使用行列,并研发出方便Python开发者使用的数据</div> </li> <li><a href="/article/1835490218845761536.htm" title="Python爬虫解析工具之xpath使用详解" target="_blank">Python爬虫解析工具之xpath使用详解</a> <span class="text-muted">eqa11</span> <a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E7%88%AC%E8%99%AB/1.htm">爬虫</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爬虫解析工具之xpath使用详解一、引言二、环境准备1、插件安装2、依赖库安装三、xpath语法详解1、路径表达式2、通配符3、谓语4、常用函数四、xpath在Python代码中的使用1、文档树的创建2、使用xpath表达式3、获取元素内容和属性五、总结Python爬虫解析工具之xpath使用详解一、引言在Python爬虫开发中,数据提取是一个至关重要的环节。xpath作为一门</div> </li> <li><a href="/article/1835470119195734016.htm" title="2.2.6 通知类控件 Toast、Menu" target="_blank">2.2.6 通知类控件 Toast、Menu</a> <span class="text-muted">常思行</span> <div>本文例程下载:WillFlow_Toast、WillFlowMenu一、什么是Toast?Toast也被叫做吐司,是Android系统提供的一种非常好的提醒方式,在程序中可以使用它将一些短小的信息通知给用户,它有如下两个特点:Toast是没有焦点的Toast显示的时间有限过一定的时间就会自动消失所以一般来讲Toast的使用并不会影响我们的正常操作,并且它通常不会占用太大的屏幕空间,有着良好的用户体</div> </li> <li><a href="/article/1835462190216343552.htm" title="第二十 python基础--语句" target="_blank">第二十 python基础--语句</a> <span class="text-muted">九樱MOL</span> <div>目录具体内容1:if语句的使用格式判断语句2:if-else的使用格式3:if-elif-else的使用格式4:if嵌套1:while循环的格式循环语句2:while循环嵌套3:for循环的格式一、判断语句在程序中如果某些条件满足,才能做某件事情,而不满足时不允许做,这就是所谓的判断1.1if语句的使用格式if要判断的条件:条件成立时,要做的事情案例:判断年纪,如果age大于18,输入成年age=</div> </li> <li><a href="/article/1835455048277127168.htm" title="Python神器!WEB自动化测试集成工具 DrissionPage" target="_blank">Python神器!WEB自动化测试集成工具 DrissionPage</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/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>一、前言用requests做数据采集面对要登录的网站时,要分析数据包、JS源码,构造复杂的请求,往往还要应付验证码、JS混淆、签名参数等反爬手段,门槛较高。若数据是由JS计算生成的,还须重现计算过程,体验不好,开发效率不高。使用浏览器,可以很大程度上绕过这些坑,但浏览器运行效率不高。因此,这个库设计初衷,是将它们合而为一,能够在不同须要时切换相应模式,并提供一种人性化的使用方法,提高开发和运行效率</div> </li> <li><a href="/article/1835450257979305984.htm" title="如何用matlab灵活控制feko的求解" target="_blank">如何用matlab灵活控制feko的求解</a> <span class="text-muted">NingrLi</span> <a class="tag" taget="_blank" href="/search/matlab/1.htm">matlab</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>https://bbs.rfeda.cn/read.php?tid=3778Feko中的模型和求解设置等都可以通过editfeko进行设置,其文件存储为.pre文件,该文件可以用文本打开,因此,我们可以通过VB、VC、matlab等工具对.pre文件进行读写操作,以达到更灵活的使用feko。同样,对于.out文件,我们也可以进行读操作。熟练使用对.pre文件和.out文件的操作后,我们可以方便的计</div> </li> <li><a href="/article/1835446560582889472.htm" title="怎么做才能真正限制塑料袋的使用?" target="_blank">怎么做才能真正限制塑料袋的使用?</a> <span class="text-muted">BalNews</span> <div>Environmentalpollutionisalwaysamajorlivelihoodissue.Morethanadecadeago,ourgovernmenthadintroducedapolicyaboutrestrictionsontheuseofplasticbags,wecallitrestrictionsontheuseofplasticbags.Butmorethan10ye</div> </li> <li><a href="/article/1835443013749403648.htm" title="入门MySQL——查询语法练习" target="_blank">入门MySQL——查询语法练习</a> <span class="text-muted">K_un</span> <div>前言:前面几篇文章为大家介绍了DML以及DDL语句的使用方法,本篇文章将主要讲述常用的查询语法。其实MySQL官网给出了多个示例数据库供大家实用查询,下面我们以最常用的员工示例数据库为准,详细介绍各自常用的查询语法。1.员工示例数据库导入官方文档员工示例数据库介绍及下载链接:https://dev.mysql.com/doc/employee/en/employees-installation.h</div> </li> <li><a href="/article/1835423779275239424.htm" title="4款毕业论文参考文献格式生成器(附加详细步骤)" target="_blank">4款毕业论文参考文献格式生成器(附加详细步骤)</a> <span class="text-muted">小猪包333</span> <a class="tag" taget="_blank" href="/search/%E5%86%99%E8%AE%BA%E6%96%87/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%B7%B1%E5%BA%A6%E5%AD%A6%E4%B9%A0/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><a class="tag" taget="_blank" href="/search/AI%E5%86%99%E4%BD%9C/1.htm">AI写作</a> <div>在撰写毕业论文时,参考文献的格式规范是至关重要的。为了帮助学生和学者们更高效地生成符合要求的参考文献格式,本文将详细介绍四款推荐的参考文献格式生成器,并提供详细的使用步骤。1.千笔-AIPassPaper千笔-AIPassPaper是一款先进的AI辅助论文写作工具,不仅能够自动生成大纲、开题报告,还能一键生成参考文献。AI论文,免费大纲,10分钟3万字https://www.aipaperpass</div> </li> <li><a href="/article/1835411044768509952.htm" title="字节二面" target="_blank">字节二面</a> <span class="text-muted">Redstone Monstrosity</span> <a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/%E9%9D%A2%E8%AF%95/1.htm">面试</a> <div>1.假设你是正在面试前端开发工程师的候选人,面试官让你详细说出你上一段实习过程的收获和感悟。在上一段实习过程中,我获得了宝贵的实践经验和深刻的行业洞察,以下是我的主要收获和感悟:一、专业技能提升框架应用熟练度:通过实际项目,我深入掌握了React、Vue等前端框架的使用,不仅提升了编码效率,还学会了如何根据项目需求选择合适的框架。问题解决能力:在实习期间,我遇到了许多预料之外的技术难题。通过查阅文</div> </li> <li><a href="/article/1835369569800253440.htm" title="史上最全git命令,git回滚,git命令大全" target="_blank">史上最全git命令,git回滚,git命令大全</a> <span class="text-muted">騒周</span> <a class="tag" taget="_blank" href="/search/%E5%85%B6%E4%BB%96/1.htm">其他</a><a class="tag" taget="_blank" href="/search/git/1.htm">git</a> <div>git命令大全一、Git整体理解二、由暂存区本地仓库三、由本地仓->远程仓库四、冲突处理五、Git分支操作六、bug的分支七、feature分支八、暂存的使用九、远程仓的操作十、标签的使用十一、Git配置全局信息十二、Linux的一些简单操作和一些符号的解释十三、符号解释十四、显示安装详细信息十五、gitconfig十六、Gitclone十七、Gitinit十八、gitstatus十九、gitre</div> </li> <li><a href="/article/1835354700392787968.htm" title="Nginx的使用场景:构建高效、可扩展的Web架构" target="_blank">Nginx的使用场景:构建高效、可扩展的Web架构</a> <span class="text-muted">张某布响丸辣</span> <a class="tag" taget="_blank" href="/search/nginx/1.htm">nginx</a><a class="tag" taget="_blank" href="/search/%E5%89%8D%E7%AB%AF/1.htm">前端</a><a class="tag" taget="_blank" href="/search/%E6%9E%B6%E6%9E%84/1.htm">架构</a> <div>Nginx,作为当今最流行的Web服务器和反向代理软件之一,凭借其高性能、稳定性和灵活性,在众多Web项目中扮演着核心角色。无论是个人博客、中小型网站,还是大型企业级应用,Nginx都能提供强大的支持。本文将探讨Nginx的几个主要使用场景,帮助读者理解如何在实际项目中充分利用Nginx的优势。1.静态文件服务对于包含大量静态文件(如HTML、CSS、JavaScript、图片等)的网站,Ngin</div> </li> <li><a href="/article/1835326615228346368.htm" title="什么是最好的时间管理" target="_blank">什么是最好的时间管理</a> <span class="text-muted">江千钰</span> <div>源自罗辑思维1.最近我看到一个观点,说时间管理这个事,一般方法的入手点,可能都错了。为啥?因为都是想站在自己和时间的外面,规范对时间的使用。这管理得越狠,就越是分秒必争,那样就会让自己的生活越绷越紧,最后谁都受不了。2.那真正的时间管理的秘诀是什么呢?其实秘诀就是四个字。头两个字是“沉浸”。沉浸在自己做的事里面。你可能会说,不对啊,我就是沉浸在刷手机、打游戏里面,所以才浪费时间,才需要时间管理嘛。</div> </li> <li><a href="/article/1835326359614877696.htm" title="svg图片兼容性和用法优缺点" target="_blank">svg图片兼容性和用法优缺点</a> <span class="text-muted">独行侠_ef93</span> <div>svg图片的使用方法第一次来认认真真的研究了下svg图片,之前只是在网上见过,但都是一晃而过也没当回事,最近网站改版看到同事有用到svg格式的图片,想想自己干了几年的重构也没用过,这些细节的知识是应该好好研究研究了。暂时还没研究得完全透切,先记下目前为止所看到的吧不然又给忘了。svg可缩放矢量图形(ScalableVectorGraphics),顾名思义就是任意改变其大小也不会变形,是基于可扩展标</div> </li> <li><a href="/article/1835289467791962112.htm" title="基于STM32F103C8T6定时器的PWM通道的重映射" target="_blank">基于STM32F103C8T6定时器的PWM通道的重映射</a> <span class="text-muted">—你的鼬先生</span> <a class="tag" taget="_blank" href="/search/stm32/1.htm">stm32</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><a class="tag" taget="_blank" href="/search/%E5%8D%95%E7%89%87%E6%9C%BA/1.htm">单片机</a> <div>在我们平时的的使用中,我们最常使用的是TIM2和TIM3的PWM通道,但是由于C8T6的IO口有限,所以可能会出现PWM通道的资源不够的情况,从而我们可能会使用PWM4的PWM通道,但是TIM4的PWM通道并不能直接使用,它需要进行一个重映射,不然可能会导致PWM波不能正常发送。以下就是对PWM4的PWM通道进行一个重映射#include"stm32f10x.h"//Deviceheadervoi</div> </li> <li><a href="/article/1835285180512825344.htm" title="Lombok:Java开发者的代码简化神器【后端 17】" target="_blank">Lombok:Java开发者的代码简化神器【后端 17】</a> <span class="text-muted">终末圆</span> <a class="tag" taget="_blank" href="/search/Java%E5%90%8E%E7%AB%AF/1.htm">Java后端</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</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/mysql/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/%E5%90%8E%E7%AB%AF/1.htm">后端</a><a class="tag" taget="_blank" href="/search/spring/1.htm">spring</a><a class="tag" taget="_blank" href="/search/boot/1.htm">boot</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a> <div>Lombok:Java开发者的代码简化神器在Java开发中,我们经常需要编写大量的样板代码,如getter、setter、equals、hashCode、toString等方法。这些代码虽然基础且必要,但往往占据了大量开发时间,且容易在属性变更时引发错误。幸运的是,Lombok这个Java库通过注解的方式,为我们提供了一种高效的解决方案。本文将详细介绍Lombok的使用及其优势。什么是Lombok</div> </li> <li><a href="/article/1835254679521554432.htm" title="深入理解AOP(面向切面编程)及其应用" target="_blank">深入理解AOP(面向切面编程)及其应用</a> <span class="text-muted">自身就是太阳</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</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/spring/1.htm">spring</a> <div>目录AOP的核心概念AOP的实现方式1.定义DAO接口和实现类2.定义通知类3.开启AOP注解驱动切入点表达式通配符的使用:AOP通知类型案例分析:测量业务层接口的执行效率结论概述:AOP(Aspect-OrientedProgramming,面向切面编程)是一种编程范式,主要用于将共性功能从具体的业务逻辑中分离出来,实现松耦合的代码设计。其作用是在不修改原始代码的情况下,对现有方法进行增强,广泛</div> </li> <li><a href="/article/1835239174261796864.htm" title="Vector和Stack的用法" target="_blank">Vector和Stack的用法</a> <span class="text-muted">蟹道人</span> <a class="tag" taget="_blank" href="/search/JavaSe/1.htm">JavaSe</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div>/***作者:*日期:*功能:vector的用法*/packagecom.cg;importjava.util.*;publicclassDemo5{publicstaticvoidmain(String[]args){//Vector的使用Vectorvec=newVector();Empemp=newEmp("2011",25,"zhang");vec.add(emp);for(inti=0;</div> </li> <li><a href="/article/1835205355223740416.htm" title="如何使用并提高批判性思考能力?" target="_blank">如何使用并提高批判性思考能力?</a> <span class="text-muted">颍水书生</span> <div>学会一个技能的最好办法就是不断的使用,学英语如此、学游泳如此、学吉他也是如此。作人类最核心的技能,学会思考的最重要的方法不是学,而是不断的对心智的积极运用。如何使用心智,则是一个相对不容易的事情,因为思考结果的没有明显的反馈,不像游泳,换气、泳姿、游的速度这些都是可以量化,水平的高低,很容易考评,甚至一眼就能看出来。不过不容易也未必是无章可循,就像我们在读书时那样,可以先来个摸底考试,看看自己水平</div> </li> <li><a href="/article/1835186856791207936.htm" title="9.15初识指针" target="_blank">9.15初识指针</a> <span class="text-muted">西科Monesy</span> <a class="tag" taget="_blank" href="/search/c%E8%AF%AD%E8%A8%80/1.htm">c语言</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a> <div>初识指针什么是指针?指针是一种数据类型,它存储了变量的内存地址。通过指针,程序可以直接访问和操作内存中的数据,而不是通过变量的名称。这使得C语言在内存管理和性能优化方面具有很大的灵活性。内存是什么?内存是电脑上的存储器,计算机中程序的运行都是在内存中进行的。程序中如果有数据需要存储也会申请内存空间。为了有效的使用内存,就把内存划分成一个小小的内存单元,每个内存单元的大小是一个字节。为了能够有效的访</div> </li> <li><a href="/article/1835186183265677312.htm" title="深入探讨:如何在Python中通过LangChain技术精准追踪大型语言模型(LLM)的Token使用情况" target="_blank">深入探讨:如何在Python中通过LangChain技术精准追踪大型语言模型(LLM)的Token使用情况</a> <span class="text-muted">m0_57781768</span> <a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/langchain/1.htm">langchain</a><a class="tag" taget="_blank" href="/search/%E8%AF%AD%E8%A8%80%E6%A8%A1%E5%9E%8B/1.htm">语言模型</a> <div>深入探讨:如何在Python中通过LangChain技术精准追踪大型语言模型(LLM)的Token使用情况在现代的人工智能开发中,大型语言模型(LLM)已经成为了不可或缺的工具,无论是用于自然语言处理、对话生成,还是其他复杂的文本生成任务。然而,随着这些模型的广泛应用,开发者面临的一个重要挑战是如何有效地追踪和管理Token的使用情况,特别是在生产环境中,Token的使用直接影响着API调用的成本</div> </li> <li><a href="/article/1835171434620612608.htm" title="Java中四种常用的数组复制的方法copyOf(),arraycop(),clone()和copyOfRange()的使用与区别" target="_blank">Java中四种常用的数组复制的方法copyOf(),arraycop(),clone()和copyOfRange()的使用与区别</a> <span class="text-muted">方九九</span> <a class="tag" taget="_blank" href="/search/java%E7%9F%A5%E8%AF%86%E7%82%B9%E6%80%BB%E7%BB%93/1.htm">java知识点总结</a><a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div>所谓复制数组,是指将一个数组中的元素在另一个数组中进行复制。本文主要介绍关于Java里面的数组复制(拷贝)的几种方式和用法。在Java中实现数组复制分别有以下4种方法:1.Arrays类的copyOf()方法2.Arrays类的copyOfRange()方法3.System类的arraycopy()方法4.Object类的clone()方法下面来详细介绍这4种方法的使用。使用copyOf()方法和</div> </li> <li><a href="/article/1835166339640160256.htm" title="年底了,积分也要清零了,该兑就兑了吧,清零就可惜了" target="_blank">年底了,积分也要清零了,该兑就兑了吧,清零就可惜了</a> <span class="text-muted">遇见yh</span> <div>年底了,许多平台的积分也要清零了,信用卡、电话卡的积分也攒了不少,该兑就得兑了,如果不兑,到年底也都会被清零。所以如果你的使用的平台,现在还有积分的话,就赶快去兑换一下,如果清零就太可惜了。前几天我登录联通官网一看,上面也有1000多个积分,就去兑换了一件麦芯粉。还有支付宝积分,也可以兑换自己需要的东西,我昨天就兑了一盒脱骨鸡爪。之前还兑过一箱全麦面包,品质都不错。这些东西都是平台送的,你不去兑换</div> </li> <li><a href="/article/1835155555543511040.htm" title="笔记:Python顺序结构 练习题" target="_blank">笔记:Python顺序结构 练习题</a> <span class="text-muted">辞言i</span> <a class="tag" taget="_blank" href="/search/%E7%AC%94%E8%AE%B0/1.htm">笔记</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a> <div>文章目录前言一、什么是顺序结构?二、练习题1.题目2.填空题3.简答题4.编程题总结前言本次笔记旨在帮助读者加深对Python编程语言中顺序结构和选择题的理解。在学习Python编程过程中,掌握程序的基本结构以及条件语句的使用至关重要。通过本次练习题,读者将有机会测试自己对这些概念的掌握程度,并通过实际应用进一步巩固所学知识。本次练习题将涵盖Python中的顺序结构的练习题,旨在帮助读者提高解决问</div> </li> <li><a href="/article/1835153599051689984.htm" title="怎样使用淘宝优惠券?全面解析优惠券使用技巧" target="_blank">怎样使用淘宝优惠券?全面解析优惠券使用技巧</a> <span class="text-muted">氧惠_飞智666999</span> <div>在数字化的购物时代,淘宝优惠券已经成为我们享受购物优惠的重要途径。然而,许多消费者在领取了优惠券后,却不知如何正确使用,导致优惠券的价值无法得到充分发挥。那么,怎样使用淘宝优惠券呢?本文将为您全面解析优惠券的使用技巧,助您轻松享受购物优惠。首先,我们需要了解优惠券的来源。淘宝优惠券可以通过多种途径获取,如淘宝官方活动页面、店铺首页、品牌官方账号等。同时,一些第三方平台也会提供淘宝优惠券的领取服务。</div> </li> <li><a href="/article/65.htm" title="Java常用排序算法/程序员必须掌握的8大排序算法" target="_blank">Java常用排序算法/程序员必须掌握的8大排序算法</a> <span class="text-muted">cugfy</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div>分类: 1)插入排序(直接插入排序、希尔排序) 2)交换排序(冒泡排序、快速排序) 3)选择排序(直接选择排序、堆排序) 4)归并排序 5)分配排序(基数排序) 所需辅助空间最多:归并排序 所需辅助空间最少:堆排序 平均速度最快:快速排序 不稳定:快速排序,希尔排序,堆排序。 先来看看8种排序之间的关系:   1.直接插入排序 (1</div> </li> <li><a href="/article/192.htm" title="【Spark102】Spark存储模块BlockManager剖析" target="_blank">【Spark102】Spark存储模块BlockManager剖析</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/manager/1.htm">manager</a> <div>Spark围绕着BlockManager构建了存储模块,包括RDD,Shuffle,Broadcast的存储都使用了BlockManager。而BlockManager在实现上是一个针对每个应用的Master/Executor结构,即Driver上BlockManager充当了Master角色,而各个Slave上(具体到应用范围,就是Executor)的BlockManager充当了Slave角色</div> </li> <li><a href="/article/319.htm" title="linux 查看端口被占用情况详解" target="_blank">linux 查看端口被占用情况详解</a> <span class="text-muted">daizj</span> <a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/%E7%AB%AF%E5%8F%A3%E5%8D%A0%E7%94%A8/1.htm">端口占用</a><a class="tag" taget="_blank" href="/search/netstat/1.htm">netstat</a><a class="tag" taget="_blank" href="/search/lsof/1.htm">lsof</a> <div>经常在启动一个程序会碰到端口被占用,这里讲一下怎么查看端口是否被占用,及哪个程序占用,怎么Kill掉已占用端口的程序   1、lsof -i:port port为端口号   [root@slave /data/spark-1.4.0-bin-cdh4]# lsof -i:8080 COMMAND   PID USER   FD   TY</div> </li> <li><a href="/article/446.htm" title="Hosts文件使用" target="_blank">Hosts文件使用</a> <span class="text-muted">周凡杨</span> <a class="tag" taget="_blank" href="/search/hosts/1.htm">hosts</a><a class="tag" taget="_blank" href="/search/locahost/1.htm">locahost</a> <div>     一切都要从localhost说起,经常在tomcat容器起动后,访问页面时输入http://localhost:8088/index.jsp,大家都知道localhost代表本机地址,如果本机IP是10.10.134.21,那就相当于http://10.10.134.21:8088/index.jsp,有时候也会看到http: 127.0.0.1:</div> </li> <li><a href="/article/573.htm" title="java excel工具" target="_blank">java excel工具</a> <span class="text-muted">g21121</span> <a class="tag" taget="_blank" href="/search/Java+excel/1.htm">Java excel</a> <div>直接上代码,一看就懂,利用的是jxl: import java.io.File; import java.io.IOException; import jxl.Cell; import jxl.Sheet; import jxl.Workbook; import jxl.read.biff.BiffException; import jxl.write.Label; import </div> </li> <li><a href="/article/700.htm" title="web报表工具finereport常用函数的用法总结(数组函数)" target="_blank">web报表工具finereport常用函数的用法总结(数组函数)</a> <span class="text-muted">老A不折腾</span> <a class="tag" taget="_blank" href="/search/finereport/1.htm">finereport</a><a class="tag" taget="_blank" href="/search/web%E6%8A%A5%E8%A1%A8/1.htm">web报表</a><a class="tag" taget="_blank" href="/search/%E5%87%BD%E6%95%B0%E6%80%BB%E7%BB%93/1.htm">函数总结</a> <div>ADD2ARRAY ADDARRAY(array,insertArray, start):在数组第start个位置插入insertArray中的所有元素,再返回该数组。 示例: ADDARRAY([3,4, 1, 5, 7], [23, 43, 22], 3)返回[3, 4, 23, 43, 22, 1, 5, 7]. ADDARRAY([3,4, 1, 5, 7], "测试&q</div> </li> <li><a href="/article/827.htm" title="游戏服务器网络带宽负载计算" target="_blank">游戏服务器网络带宽负载计算</a> <span class="text-muted">墙头上一根草</span> <a class="tag" taget="_blank" href="/search/%E6%9C%8D%E5%8A%A1%E5%99%A8/1.htm">服务器</a> <div>家庭所安装的4M,8M宽带。其中M是指,Mbits/S 其中要提前说明的是: 8bits = 1Byte 即8位等于1字节。我们硬盘大小50G。意思是50*1024M字节,约为 50000多字节。但是网宽是以“位”为单位的,所以,8Mbits就是1M字节。是容积体积的单位。 8Mbits/s后面的S是秒。8Mbits/s意思是 每秒8M位,即每秒1M字节。 我是在计算我们网络流量时想到的</div> </li> <li><a href="/article/954.htm" title="我的spring学习笔记2-IoC(反向控制 依赖注入)" target="_blank">我的spring学习笔记2-IoC(反向控制 依赖注入)</a> <span class="text-muted">aijuans</span> <a class="tag" taget="_blank" href="/search/Spring+3+%E7%B3%BB%E5%88%97/1.htm">Spring 3 系列</a> <div>IoC(反向控制 依赖注入)这是Spring提出来了,这也是Spring一大特色。这里我不用多说,我们看Spring教程就可以了解。当然我们不用Spring也可以用IoC,下面我将介绍不用Spring的IoC。 IoC不是框架,她是java的技术,如今大多数轻量级的容器都会用到IoC技术。这里我就用一个例子来说明: 如:程序中有 Mysql.calss 、Oracle.class 、SqlSe</div> </li> <li><a href="/article/1081.htm" title="高性能mysql 之 选择存储引擎(一)" target="_blank">高性能mysql 之 选择存储引擎(一)</a> <span class="text-muted">annan211</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/InnoDB/1.htm">InnoDB</a><a class="tag" taget="_blank" href="/search/MySQL%E5%BC%95%E6%93%8E/1.htm">MySQL引擎</a><a class="tag" taget="_blank" href="/search/%E5%AD%98%E5%82%A8%E5%BC%95%E6%93%8E/1.htm">存储引擎</a> <div> 1 没有特殊情况,应尽可能使用InnoDB存储引擎。   原因:InnoDB 和 MYIsAM 是mysql 最常用、使用最普遍的存储引擎。其中InnoDB是最重要、最广泛的存储引擎。她   被设计用来处理大量的短期事务。短期事务大部分情况下是正常提交的,很少有回滚的情况。InnoDB的性能和自动崩溃   恢复特性使得她在非事务型存储的需求中也非常流行,除非有非常</div> </li> <li><a href="/article/1208.htm" title="UDP网络编程" target="_blank">UDP网络编程</a> <span class="text-muted">百合不是茶</span> <a class="tag" taget="_blank" href="/search/UDP%E7%BC%96%E7%A8%8B/1.htm">UDP编程</a><a class="tag" taget="_blank" href="/search/%E5%B1%80%E5%9F%9F%E7%BD%91%E7%BB%84%E6%92%AD/1.htm">局域网组播</a> <div>  UDP是基于无连接的,不可靠的传输   与TCP/IP相反       UDP实现私聊,发送方式客户端,接受方式服务器 package netUDP_sc; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.Ine</div> </li> <li><a href="/article/1335.htm" title="JQuery对象的val()方法执行结果分析" target="_blank">JQuery对象的val()方法执行结果分析</a> <span class="text-muted">bijian1013</span> <a class="tag" taget="_blank" href="/search/JavaScript/1.htm">JavaScript</a><a class="tag" taget="_blank" href="/search/js/1.htm">js</a><a class="tag" taget="_blank" href="/search/jquery/1.htm">jquery</a> <div>        JavaScript中,如果id对应的标签不存在(同理JAVA中,如果对象不存在),则调用它的方法会报错或抛异常。在实际开发中,发现JQuery在id对应的标签不存在时,调其val()方法不会报错,结果是undefined。         </div> </li> <li><a href="/article/1462.htm" title="http请求测试实例(采用json-lib解析)" target="_blank">http请求测试实例(采用json-lib解析)</a> <span class="text-muted">bijian1013</span> <a class="tag" taget="_blank" href="/search/json/1.htm">json</a><a class="tag" taget="_blank" href="/search/http/1.htm">http</a> <div>        由于fastjson只支持JDK1.5版本,因些对于JDK1.4的项目,可以采用json-lib来解析JSON数据。如下是http请求的另外一种写法,仅供参考。 package com; import java.util.HashMap; import java.util.Map; import </div> </li> <li><a href="/article/1589.htm" title="【RPC框架Hessian四】Hessian与Spring集成" target="_blank">【RPC框架Hessian四】Hessian与Spring集成</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/hessian/1.htm">hessian</a> <div>在【RPC框架Hessian二】Hessian 对象序列化和反序列化一文中介绍了基于Hessian的RPC服务的实现步骤,在那里使用Hessian提供的API完成基于Hessian的RPC服务开发和客户端调用,本文使用Spring对Hessian的集成来实现Hessian的RPC调用。   定义模型、接口和服务器端代码 |---Model    &nb</div> </li> <li><a href="/article/1716.htm" title="【Mahout三】基于Mahout CBayes算法的20newsgroup流程分析" target="_blank">【Mahout三】基于Mahout CBayes算法的20newsgroup流程分析</a> <span class="text-muted">bit1129</span> <a class="tag" taget="_blank" href="/search/Mahout/1.htm">Mahout</a> <div>1.Mahout环境搭建  1.下载Mahout http://mirror.bit.edu.cn/apache/mahout/0.10.0/mahout-distribution-0.10.0.tar.gz    2.解压Mahout  3. 配置环境变量 vim /etc/profile export HADOOP_HOME=/home</div> </li> <li><a href="/article/1843.htm" title="nginx负载tomcat遇非80时的转发问题" target="_blank">nginx负载tomcat遇非80时的转发问题</a> <span class="text-muted">ronin47</span> <div>  nginx负载后端容器是tomcat(其它容器如WAS,JBOSS暂没发现这个问题)非80端口,遇到跳转异常问题。解决的思路是:$host:port        详细如下:    该问题是最先发现的,由于之前对nginx不是特别的熟悉所以该问题是个入门级别的: ? 1 2 3 4 5 </div> </li> <li><a href="/article/1970.htm" title="java-17-在一个字符串中找到第一个只出现一次的字符" target="_blank">java-17-在一个字符串中找到第一个只出现一次的字符</a> <span class="text-muted">bylijinnan</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a> <div> public class FirstShowOnlyOnceElement { /**Q17.在一个字符串中找到第一个只出现一次的字符。如输入abaccdeff,则输出b * 1.int[] count:count[i]表示i对应字符出现的次数 * 2.将26个英文字母映射:a-z <--> 0-25 * 3.假设全部字母都是小写 */ pu</div> </li> <li><a href="/article/2097.htm" title="mongoDB 复制集" target="_blank">mongoDB 复制集</a> <span class="text-muted">开窍的石头</span> <a class="tag" taget="_blank" href="/search/mongodb/1.htm">mongodb</a> <div>mongo的复制集就像mysql的主从数据库,当你往其中的主复制集(primary)写数据的时候,副复制集(secondary)会自动同步主复制集(Primary)的数据,当主复制集挂掉以后其中的一个副复制集会自动成为主复制集。提供服务器的可用性。和防止当机问题             mo</div> </li> <li><a href="/article/2224.htm" title="[宇宙与天文]宇宙时代的经济学" target="_blank">[宇宙与天文]宇宙时代的经济学</a> <span class="text-muted">comsci</span> <a class="tag" taget="_blank" href="/search/%E7%BB%8F%E6%B5%8E/1.htm">经济</a> <div>     宇宙尺度的交通工具一般都体型巨大,造价高昂。。。。。      在宇宙中进行航行,近程采用反作用力类型的发动机,需要消耗少量矿石燃料,中远程航行要采用量子或者聚变反应堆发动机,进行超空间跳跃,要消耗大量高纯度水晶体能源      以目前地球上国家的经济发展水平来讲,</div> </li> <li><a href="/article/2351.htm" title="Git忽略文件" target="_blank">Git忽略文件</a> <span class="text-muted">Cwind</span> <a class="tag" taget="_blank" href="/search/git/1.htm">git</a> <div>     有很多文件不必使用git管理。例如Eclipse或其他IDE生成的项目文件,编译生成的各种目标或临时文件等。使用git status时,会在Untracked files里面看到这些文件列表,在一次需要添加的文件比较多时(使用git add . / git add -u),会把这些所有的未跟踪文件添加进索引。 ==== ==== ==== 一些牢骚</div> </li> <li><a href="/article/2478.htm" title="MySQL连接数据库的必须配置" target="_blank">MySQL连接数据库的必须配置</a> <span class="text-muted">dashuaifu</span> <a class="tag" taget="_blank" href="/search/mysql/1.htm">mysql</a><a class="tag" taget="_blank" href="/search/%E8%BF%9E%E6%8E%A5%E6%95%B0%E6%8D%AE%E5%BA%93%E9%85%8D%E7%BD%AE/1.htm">连接数据库配置</a> <div>MySQL连接数据库的必须配置   1.driverClass:com.mysql.jdbc.Driver   2.jdbcUrl:jdbc:mysql://localhost:3306/dbname   3.user:username   4.password:password   其中1是驱动名;2是url,这里的‘dbna</div> </li> <li><a href="/article/2605.htm" title="一生要养成的60个习惯" target="_blank">一生要养成的60个习惯</a> <span class="text-muted">dcj3sjt126com</span> <a class="tag" taget="_blank" href="/search/%E4%B9%A0%E6%83%AF/1.htm">习惯</a> <div>一生要养成的60个习惯 第1篇 让你更受大家欢迎的习惯 1 守时,不准时赴约,让别人等,会失去很多机会。 如何做到: ①该起床时就起床, ②养成任何事情都提前15分钟的习惯。 ③带本可以随时阅读的书,如果早了就拿出来读读。 ④有条理,生活没条理最容易耽误时间。 ⑤提前计划:将重要和不重要的事情岔开。 ⑥今天就准备好明天要穿的衣服。 ⑦按时睡觉,这会让按时起床更容易。 2 注重</div> </li> <li><a href="/article/2732.htm" title="[介绍]Yii 是什么" target="_blank">[介绍]Yii 是什么</a> <span class="text-muted">dcj3sjt126com</span> <a class="tag" taget="_blank" href="/search/PHP/1.htm">PHP</a><a class="tag" taget="_blank" href="/search/yii2/1.htm">yii2</a> <div>Yii 是一个高性能,基于组件的 PHP 框架,用于快速开发现代 Web 应用程序。名字 Yii (读作 易)在中文里有“极致简单与不断演变”两重含义,也可看作 Yes It Is! 的缩写。 Yii 最适合做什么? Yii 是一个通用的 Web 编程框架,即可以用于开发各种用 PHP 构建的 Web 应用。因为基于组件的框架结构和设计精巧的缓存支持,它特别适合开发大型应</div> </li> <li><a href="/article/2859.htm" title="Linux SSH常用总结" target="_blank">Linux SSH常用总结</a> <span class="text-muted">eksliang</span> <a class="tag" taget="_blank" href="/search/linux+ssh/1.htm">linux ssh</a><a class="tag" taget="_blank" href="/search/SSHD/1.htm">SSHD</a> <div>转载请出自出处:http://eksliang.iteye.com/blog/2186931 一、连接到远程主机   格式: ssh name@remoteserver 例如: ssh ickes@192.168.27.211   二、连接到远程主机指定的端口   格式: ssh name@remoteserver -p 22 例如: ssh i</div> </li> <li><a href="/article/2986.htm" title="快速上传头像到服务端工具类FaceUtil" target="_blank">快速上传头像到服务端工具类FaceUtil</a> <span class="text-muted">gundumw100</span> <a class="tag" taget="_blank" href="/search/android/1.htm">android</a> <div>快速迭代用 import java.io.DataOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOExceptio</div> </li> <li><a href="/article/3113.htm" title="jQuery入门之怎么使用" target="_blank">jQuery入门之怎么使用</a> <span class="text-muted">ini</span> <a class="tag" taget="_blank" href="/search/JavaScript/1.htm">JavaScript</a><a class="tag" taget="_blank" href="/search/html/1.htm">html</a><a class="tag" taget="_blank" href="/search/jquery/1.htm">jquery</a><a class="tag" taget="_blank" href="/search/Web/1.htm">Web</a><a class="tag" taget="_blank" href="/search/css/1.htm">css</a> <div>jQuery的强大我何问起(个人主页:hovertree.com)就不用多说了,那么怎么使用jQuery呢?   首先,下载jquery。下载地址:http://hovertree.com/hvtart/bjae/b8627323101a4994.htm,一个是压缩版本,一个是未压缩版本,如果在开发测试阶段,可以使用未压缩版本,实际应用一般使用压缩版本(min)。然后就在页面上引用。</div> </li> <li><a href="/article/3240.htm" title="带filter的hbase查询优化" target="_blank">带filter的hbase查询优化</a> <span class="text-muted">kane_xie</span> <a class="tag" taget="_blank" href="/search/%E6%9F%A5%E8%AF%A2%E4%BC%98%E5%8C%96/1.htm">查询优化</a><a class="tag" taget="_blank" href="/search/hbase/1.htm">hbase</a><a class="tag" taget="_blank" href="/search/RandomRowFilter/1.htm">RandomRowFilter</a> <div> 问题描述 hbase scan数据缓慢,server端出现LeaseException。hbase写入缓慢。   问题原因 直接原因是: hbase client端每次和regionserver交互的时候,都会在服务器端生成一个Lease,Lease的有效期由参数hbase.regionserver.lease.period确定。如果hbase scan需</div> </li> <li><a href="/article/3367.htm" title="java设计模式-单例模式" target="_blank">java设计模式-单例模式</a> <span class="text-muted">men4661273</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E4%BE%8B/1.htm">单例</a><a class="tag" taget="_blank" href="/search/%E6%9E%9A%E4%B8%BE/1.htm">枚举</a><a class="tag" taget="_blank" href="/search/%E5%8F%8D%E5%B0%84/1.htm">反射</a><a class="tag" taget="_blank" href="/search/IOC/1.htm">IOC</a> <div>         单例模式1,饿汉模式 //饿汉式单例类.在类初始化时,已经自行实例化 public class Singleton1 { //私有的默认构造函数 private Singleton1() {} //已经自行实例化 private static final Singleton1 singl</div> </li> <li><a href="/article/3494.htm" title="mongodb 查询某一天所有信息的3种方法,根据日期查询" target="_blank">mongodb 查询某一天所有信息的3种方法,根据日期查询</a> <span class="text-muted">qiaolevip</span> <a class="tag" taget="_blank" href="/search/%E6%AF%8F%E5%A4%A9%E8%BF%9B%E6%AD%A5%E4%B8%80%E7%82%B9%E7%82%B9/1.htm">每天进步一点点</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0%E6%B0%B8%E6%97%A0%E6%AD%A2%E5%A2%83/1.htm">学习永无止境</a><a class="tag" taget="_blank" href="/search/mongodb/1.htm">mongodb</a><a class="tag" taget="_blank" href="/search/%E7%BA%B5%E8%A7%82%E5%8D%83%E8%B1%A1/1.htm">纵观千象</a> <div>// mongodb的查询真让人难以琢磨,就查询单天信息,都需要花费一番功夫才行。 // 第一种方式: coll.aggregate([ {$project:{sendDate: {$substr: ['$sendTime', 0, 10]}, sendTime: 1, content:1}}, {$match:{sendDate: '2015-</div> </li> <li><a href="/article/3621.htm" title="二维数组转换成JSON" target="_blank">二维数组转换成JSON</a> <span class="text-muted">tangqi609567707</span> <a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E4%BA%8C%E7%BB%B4%E6%95%B0%E7%BB%84/1.htm">二维数组</a><a class="tag" taget="_blank" href="/search/json/1.htm">json</a> <div>原文出处:http://blog.csdn.net/springsen/article/details/7833596 public class Demo {     public static void main(String[] args) {        String[][] blogL</div> </li> <li><a href="/article/3748.htm" title="erlang supervisor" target="_blank">erlang supervisor</a> <span class="text-muted">wudixiaotie</span> <a class="tag" taget="_blank" href="/search/erlang/1.htm">erlang</a> <div>定义supervisor时,如果是监控celuesimple_one_for_one则删除children的时候就用supervisor:terminate_child (SupModuleName, ChildPid),如果shutdown策略选择的是brutal_kill,那么supervisor会调用exit(ChildPid, kill),这样的话如果Child的behavior是gen_</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>