2012年5月28日

Union 和 Union ALL 的区别

.

.

.

.

.

Union 与 Union ALL 的作用都是合并 SELECT 的查询结果集,那么它们有什么不同呢?

Union 将查询到的结果集合并后进行重查,将其中相同的行去除。缺点:效率低;

而Union ALL 则只是合并查询的结果集,并不重新查询,效率高,但是可能会出现冗余数据。

我们举个例子来说明一下:

比如数据库中有两张表 tab1 和 tab2。

tab1 中的数据有:

小王
小张

tab2 中的数据有:

小王
小李

 

执行查询:

1 SELECT * FROM tab1 UNION SELECT * FROM tab2

结果如下:

小王
小张
小李

 

如果执行如下查询:

1 SELECT * FROM tab1 UNION ALL SELECT * FROM tab2

则结果如下:

小王
小张
小王
小李

 

这回看出来有什么不同了吧?

posted @ 2012-05-28 11:10 yuhuashi 阅读(1) 评论(0) 编辑

2012年5月11日

MyEclipse + Weblogic 11g 每次 debug 时要求 Edit Source Lookup Path 添加被调试项目的解决方案

.

.

.

.

.

最近刚刚用了 MyEclipse + Weblogic 环境,调试项目时总是提示 Edit Source Lookup Path,然后需要选择被调试的项目,否则不能看到调试的源代码执行步骤。在网上查了些资料,但是也没有找到合适的,最后终于自己鼓捣出来了。

这样太麻烦,我们手工配置一下 Weblogic 就可以了。

Window -- Preferences -- MyEclipse -- Servers -- WebLogic -- WebLogic 10.x

在右侧选择 Disable 禁用默认的 WebLogic 服务器。

然后选择子菜单:Launch

在弹出的新窗口中选择 "Source" 选项卡。

根据上图的配置方法将需要调试的项目添加到服务器中。

OK 了,下断点启动服务吧。

posted @ 2012-05-11 11:16 yuhuashi 阅读(17) 评论(0) 编辑

2012年5月6日

windows 中 Eclipse 打开当前文件所在文件夹

.

.

.

.

.

默认情况下使用eclipse打开当前文件所在文件夹很麻烦,需要右键点击 Package Explorer 中的节点选择属性,然后复制路径,再打开资源管理器,然后再把路径粘贴进去。而MyEclipse一直有一个很好用的工具在工具栏上,只要选中 Package Explorer 的节点,一点击这个图标就可以在资源管理器中打开文件了。

MyEclipse 里面的插件名叫:Desktop toolbar。

于是我就在 Eclipse 的工具栏配置中寻找这个插件,可是没有找到,经过在网上查阅资料后,终于找到了一个模拟这个插件的办法,配置和操作起来也比较简单,在这里分享给大家。

依次展开如下菜单:

Run ---- External Tools ---- External Tools Configurations

1.在 program 下面新建一个工具;

2.在 Location 中填写 windows 资源管理器路径;

3.在 Arguments 中填写 ${container_loc};(不带分号)

4.选择 Common 选项卡;

5.选中 External Tools 复选框(使该项出现在工具栏中);

6.点击 Apply 按钮。

好了,单击工具栏上的 External Tools 按钮即可在资源管理器中打开你在 Package Explorer 中选中的文件所在的目录了。

posted @ 2012-05-06 11:52 yuhuashi 阅读(79) 评论(0) 编辑

2012年4月28日

在windows中将Tomcat作为服务启动

.

.

.

.

.

在web服务器上通常需要是web容器随开机自动启动,恰好Tomcat可以作为服务启动,只要经过我们简单的配置,就可以将免安装版的Tomcat添加到系统服务中。

首先需要配置以下环境变量:

JAVA_HOME:JDK 路径

JRE_HOME:JRE 路径

CATALINA_HOME:Tomcat 路径

在 path 环境变量最前面加入:%JAVA_HOME%\bin;%CATALINA_HOME%\bin;

好了,环境变量配置完成,接着在 CMD 下运行 service.bat install

C:\Users\yuhuashi>service.bat install
Installing the service 'Tomcat6' ...
Using CATALINA_HOME: "D:\ProgramerFiles\apache-tomcat-6.0.35"
Using CATALINA_BASE: "D:\ProgramerFiles\apache-tomcat-6.0.35"
Using JAVA_HOME: "d:\ProgramerFiles\Java\jdk1.6.0_30\"
Using JVM: "d:\ProgramerFiles\Java\jdk1.6.0_30\\jre\bin\server\jvm.
dll"
The service 'Tomcat6' has been installed.

现在 Tomcat 服务已经安装在系统中了,继续运行 services.msc 打开服务管理控制台。

找到 Apache Tomcat 服务,右键选择属性,修改启动类型为“自动”或“自动(延迟启动)”并确定。

搞定,再次开机时 Tomcat 就会随系统自动启动了。

posted @ 2012-04-28 16:08 yuhuashi 阅读(57) 评论(0) 编辑

2012年4月26日

使用itext组件生成PDF文件

.

.

.

.

.

这几天需要做一个单据打印功能,没有找到好的办法,于是只能采用生成PDF文件,然后由客户端下载到本地进行打印,如果使用Chrome浏览器还能支持在线打印预览。

那么在这里笔者跟大家分享一下使用iText组件的方法,适用于从没有接触过iText的新手,老手请飘过。

这里纯属笔者从实践中所得的经验,如有错误或疏忽之处还请读者指正。

首先从iText的官网下载这个开源的小组件。

iText官方网站

Java版iText组件

Java版工具包

C#版iText组件

C#版工具包

这里笔者使用的是Java版itext-5.2.1。

将itext-5.2.1.zip压缩包解压缩后得到7个文件:itextpdf-5.2.1.jar(核心组件)、itextpdf-5.2.1-javadoc.jar(API文档)、itextpdf-5.2.1-sources.jar(源代码)、itext-xtra-5.2.1.jar、itext-xtra-5.2.1-javadoc.jar、itext-xtra-5.2.1-sources.jar

使用5步即可生成一个简单的PDF文档。

 1 // 1.创建 Document 对象
 2 Document _document = new Document();
 3 // 2.创建书写器,通过书写器将文档写入磁盘
 4 PdfWriter _pdfWriter = PdfWriter.getInstance(_document, new FileOutputStream("生成文件的路径"));
 5 // 3.打开文档
 6 _document.open();
 7 // 4.向文档中添加内容
 8 _document.add(new Paragraph("Hi"));
 9 // 5.关闭文档
10 _document.close();

OK,搞定,不出问题的话就会在你指定的路径中生成一个PDF文档,内容是纯文本的“Hi”。

可是这样并不能完全满足我们的需求,因为通常我们要生成的PDF文件不一定是纯文本格式的,比如我现在要实现打印销售单的功能,那么最起码需要绘制表格才行,怎么办呢?且跟笔者继续向下研究。

在iText中,有专门的表格类,即PdfPTable类。笔者做了一个简单的表格示例,请先看代码:

  1 OutTradeList _otl = this.getOtlBiz().findOutTradeListById(this.getOtlid());
  2 String _fileName = _otl.getOtlId() + ".pdf";
  3 
  4 // iText 处理中文
  5 BaseFont _baseFont = BaseFont.createFont("STSongStd-Light", "UniGB-UCS2-H", true);
  6 // 1.创建 Document 对象
  7 Document _document = new Document(PageSize.A4);
  8 
  9 HttpServletResponse response = ServletActionContext.getResponse();
 10 response.setContentType("application/pdf; charset=ISO-8859-1");
 11 response.setHeader("Content-Disposition", "inline; filename=" + new String(_fileName.getBytes(), "iso8859-1"));
 12 
 13 // 2.创建书写器,通过书写器将文档写入磁盘
 14 PdfWriter _pdfWriter = null;
 15 try {
 16      _pdfWriter = PdfWriter.getInstance(_document, response.getOutputStream());
 17 } catch (Exception e) {
 18      this.setMessage("单据生成失败,请检查服务器目录权限配置是否正确");
 19      e.printStackTrace();
 20      System.out.println("2.挂了");
 21 //   return INPUT;
 22      return null;
 23 }
 24 if(_pdfWriter == null) {
 25      this.setMessage("单据生成失败,请检查服务器目录权限配置是否正确");
 26      System.out.println("3.挂了");
 27 //   return INPUT;
 28      return null;
 29 }
 30         
 31 // 3.打开文档
 32 _document.open();
 33         
 34 // 4.创建需要填入文档的元素
 35 PdfPTable _table = new PdfPTable(4);
 36 PdfPCell _cell = null;
 37 
 38 _table.addCell(new Paragraph("单据号", new Font(_baseFont)));
 39 _cell = new PdfPCell(new Paragraph(_otl.getOtlId()));
 40 _cell.setColspan(3);
 41 _table.addCell(_cell);
 42 
 43 _table.addCell(new Paragraph("客户名称", new Font(_baseFont)));
 44 _cell = new PdfPCell(new Paragraph(_otl.getClients().getName(), new Font(_baseFont)));
 45 _cell.setColspan(3);
 46 _table.addCell(_cell);
 47 
 48 _table.addCell(new Paragraph("销售日期", new Font(_baseFont)));
 49 _cell = new PdfPCell(new Paragraph(_otl.getOutDate().toString()));
 50 _cell.setColspan(3);
 51 _table.addCell(_cell);
 52 
 53 _cell = new PdfPCell();
 54 _cell.setColspan(4);
 55 PdfPTable _tabGoods = new PdfPTable(7);
 56 // 添加标题行
 57 _tabGoods.setHeaderRows(1);
 58 _tabGoods.addCell(new Paragraph("序号", new Font(_baseFont)));
 59 _tabGoods.addCell(new Paragraph("商品名称", new Font(_baseFont)));
 60 _tabGoods.addCell(new Paragraph("自定义码", new Font(_baseFont)));
 61 _tabGoods.addCell(new Paragraph("规格", new Font(_baseFont)));
 62 _tabGoods.addCell(new Paragraph("数量", new Font(_baseFont)));
 63 _tabGoods.addCell(new Paragraph("单价", new Font(_baseFont)));
 64 _tabGoods.addCell(new Paragraph("小计", new Font(_baseFont)));
 65 Object[] _outTrades = _otl.getOutTrades().toArray(); 
66
// 将商品销售详细信息加入表格 67 for(int i = 0; i < _outTrades.length;) { 68 if((_outTrades[i] != null) && (_outTrades[i] instanceof OutTrade)) { 69 OutTrade _ot = (OutTrade) _outTrades[i]; 70 Goods _goods = _ot.getGoods(); 71 _tabGoods.addCell(String.valueOf((++i))); 72 _tabGoods.addCell(new Paragraph(_goods.getName(), new Font(_baseFont))); 73 _tabGoods.addCell(_goods.getUserCode()); 74 _tabGoods.addCell(_goods.getEtalon()); 75 _tabGoods.addCell(String.valueOf(_ot.getNum())); 76 _tabGoods.addCell(String.valueOf(_ot.getPrice())); 77 _tabGoods.addCell(String.valueOf((_ot.getNum() * _ot.getPrice()))); 78 } 79 } 80 _cell.addElement(_tabGoods); 81 _table.addCell(_cell); 82 83 _table.addCell(new Paragraph("总计", new Font(_baseFont))); 84 _cell = new PdfPCell(new Paragraph(_otl.getAllPrice().toString())); 85 _cell.setColspan(3); 86 _table.addCell(_cell); 87 88 _table.addCell(new Paragraph("操作员", new Font(_baseFont))); 89 _cell = new PdfPCell(new Paragraph(_otl.getProcure())); 90 _cell.setColspan(3); 91 _table.addCell(_cell); 92 93 // 5.向文档中添加内容,将表格加入文档中 94 _document.add(_table); 95 96 // 6.关闭文档 97 _document.close(); 98 System.out.println(_fileName); 99 this.setPdfFilePath(_fileName); 100 System.out.println("3.搞定"); 101 // return SUCCESS; 102 return null;

以上代码是写在 Struts2 的 Action 中的,当用户发送了请求之后直接将生成的PDF文件用输出流写入到客户端,浏览器收到服务器的响应之后就会询问用户打开方式。

当然,我们也可以将文件写入磁盘等等。

以下是效果图:

虽然磕碜了点,不过最基本表格已经按照我们预设的样子出现了。

好了,先写到这里,有什么问题大家可以多查查API文档,剩下的样式问题自己可以慢慢调整。

iText 还有很多强大的功能,由于笔者也是边学边用,在这里也只是把学习的结果记录下来给小菜们作为一些参考,如果有什么不正确的地方,还请各位不吝赐教。

posted @ 2012-04-26 13:20 yuhuashi 阅读(41) 评论(0) 编辑

2012年4月8日

Hibernate 异常:object references an unsaved transient instance - save the transient instance before flushing

摘要: .....今天在对两张一对多关系的表进行增加数据时,其中主表的数据增加成功了,但是子表却没有数据,这是什么原因导致的呢?在网上查询了一番之后,找到了一个解决的办法:将主表的 .hbm.xml 中的set设置为 inverse="false" 即可。inverse 是反转的意思,而 inverse="false" 则代表主控方为主表,这样将由主控方来维护关联关系(控制权交给了 One 方)。也就是当主表进行更新时,关联的子表也会进行更新。但是做了如上的更改之后,保存的时候却又发生了以下异常:object references an unsaved tran阅读全文

posted @ 2012-04-08 14:18 yuhuashi 阅读(123) 评论(0) 编辑

2012年3月29日

Hibernate 异常 Unable to instantiate default tuplizer

摘要: .....今天在做Hibernate和Spring整合,在一张表中多添加了三个字段,它们的类型分别是INT、BIT和DATETIME,然后手动修改了实体类和.hbm.xml,启动单元测试的时候遇到了一个问题,控制台上报出了一大堆异常和堆栈信息,嵌套到最终的一个异常是Unable to instantiate default tuplizer,于是开始在Google上查相关资料,查了很久,查出了几种可能导致该异常的方法,于是将其记录下来,分享给遇到同样问题的网友。第一种可能是缺少javassist.jar包,下面给出下载地址。http://mirrors.ibiblio.org/pub/mirr阅读全文

posted @ 2012-03-29 13:44 yuhuashi 阅读(15) 评论(0) 编辑

2012年3月27日

修改 MyEclipse 编辑区域背景颜色

摘要: 经常用 MyEclipse 写代码,时间久了会觉得白色的背景颜色很刺眼,于是乎便想要换一种柔和些的颜色来缓解视力疲劳,那么怎么样来修改 MyEclipse 代码编辑区域的背景颜色呢?依次展开菜单Window >> Preferences >> General >> Editors >> Text Editors选择右侧的 Background color 选项,去除 System Default 复选框的选中状态,然后点击 Color 按钮,选择一个自己看着舒适的颜色吧,然后点击 Apply 按钮,此时已经成功设置了代码编辑区域的背景颜色了。阅读全文

posted @ 2012-03-27 20:34 yuhuashi 阅读(29) 评论(0) 编辑

MyEclipse 找回安装插件的菜单

摘要: MyEclipse 的 Help 菜单中似乎找不到像 eclipse 中那个安装插件的菜单了,其实并不是 MyEclipse 没有这个菜单,只是被隐藏了而已,按照如下方式找回这个被隐藏的菜单。Window >> Preferences >> General >> Capabilities将 Classic Update 复选框选中,然后单击 Apply 按钮,看看 Help 菜单里是不是出现了 Software Updates 菜单呢?阅读全文

posted @ 2012-03-27 20:28 yuhuashi 阅读(6) 评论(0) 编辑

MyEclipse 8.5 安装 jBPM 插件

摘要: .....1.解压缩jbpm-4.4.zip文件,笔者解压缩到了D:\ProgramerFiles\jbpm-4.4目录下。2.打开MyEclipse,展开以下菜单:Help >> MyEclipse Configuration Center >> Software3.点击左上角的 add site4.选择 Add from Archive File,然后浏览并选择jBPM-4.4\install\src\gpd\jbpm-gpd-site.zip文件,然后写一个名字并点击OK5.此时左面 Personal Sites 应该已经显示了jBPM4.4,将其一级级展开,然后阅读全文

posted @ 2012-03-27 13:11 yuhuashi 阅读(310) 评论(0) 编辑

仅列出标题  下一页

导航

统计

公告