.
.
.
.
.
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
则结果如下:
这回看出来有什么不同了吧?
.
.
.
.
.
最近刚刚用了 MyEclipse + Weblogic 环境,调试项目时总是提示 Edit Source Lookup Path,然后需要选择被调试的项目,否则不能看到调试的源代码执行步骤。在网上查了些资料,但是也没有找到合适的,最后终于自己鼓捣出来了。

这样太麻烦,我们手工配置一下 Weblogic 就可以了。
Window -- Preferences -- MyEclipse -- Servers -- WebLogic -- WebLogic 10.x
在右侧选择 Disable 禁用默认的 WebLogic 服务器。
然后选择子菜单:Launch

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

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

OK 了,下断点启动服务吧。
.
.
.
.
.
默认情况下使用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 中选中的文件所在的目录了。



.
.
.
.
.
在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 就会随系统自动启动了。
.
.
.
.
.
这几天需要做一个单据打印功能,没有找到好的办法,于是只能采用生成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 还有很多强大的功能,由于笔者也是边学边用,在这里也只是把学习的结果记录下来给小菜们作为一些参考,如果有什么不正确的地方,还请各位不吝赐教。
摘要: .....今天在对两张一对多关系的表进行增加数据时,其中主表的数据增加成功了,但是子表却没有数据,这是什么原因导致的呢?在网上查询了一番之后,找到了一个解决的办法:将主表的 .hbm.xml 中的set设置为 inverse="false" 即可。inverse 是反转的意思,而 inverse="false" 则代表主控方为主表,这样将由主控方来维护关联关系(控制权交给了 One 方)。也就是当主表进行更新时,关联的子表也会进行更新。但是做了如上的更改之后,保存的时候却又发生了以下异常:object references an unsaved tran
阅读全文
摘要: .....今天在做Hibernate和Spring整合,在一张表中多添加了三个字段,它们的类型分别是INT、BIT和DATETIME,然后手动修改了实体类和.hbm.xml,启动单元测试的时候遇到了一个问题,控制台上报出了一大堆异常和堆栈信息,嵌套到最终的一个异常是Unable to instantiate default tuplizer,于是开始在Google上查相关资料,查了很久,查出了几种可能导致该异常的方法,于是将其记录下来,分享给遇到同样问题的网友。第一种可能是缺少javassist.jar包,下面给出下载地址。http://mirrors.ibiblio.org/pub/mirr
阅读全文
摘要: 经常用 MyEclipse 写代码,时间久了会觉得白色的背景颜色很刺眼,于是乎便想要换一种柔和些的颜色来缓解视力疲劳,那么怎么样来修改 MyEclipse 代码编辑区域的背景颜色呢?依次展开菜单Window >> Preferences >> General >> Editors >> Text Editors选择右侧的 Background color 选项,去除 System Default 复选框的选中状态,然后点击 Color 按钮,选择一个自己看着舒适的颜色吧,然后点击 Apply 按钮,此时已经成功设置了代码编辑区域的背景颜色了。
阅读全文
摘要: MyEclipse 的 Help 菜单中似乎找不到像 eclipse 中那个安装插件的菜单了,其实并不是 MyEclipse 没有这个菜单,只是被隐藏了而已,按照如下方式找回这个被隐藏的菜单。Window >> Preferences >> General >> Capabilities将 Classic Update 复选框选中,然后单击 Apply 按钮,看看 Help 菜单里是不是出现了 Software Updates 菜单呢?
阅读全文
摘要: .....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,将其一级级展开,然后
阅读全文