实体更新
Transaction trans=session.beginTransaction();   
String hql=”update User user set user.age=20 where user.age=18”;   
Query queryupdate=session.createQuery(hql);   
int ret=queryupdate.executeUpdate();   
trans.commit();
实体删除
Transaction trans=session.beginTransaction();   
String hql=”delete from User user where user.age=18”;   
Query queryupdate=session.createQuery(hql);   
int ret=queryupdate.executeUpdate();   
trans.commit();
属性查询
List list=session.createQuery(“select user.name from User user ”).list();   
for(int i=0){   System.out.println(list.get(i));   }

一次检索多个属性,如下面程序:   
List list=session.createQuery(“select user.name,user.age from User user ”).list();   for(int i=0;i<list.length();i++){   Object[] obj=(Object[])list.get(i);   System.out.println(obj[0]);   System.out.println(obj[1]);   }

posted @ 2011-11-22 09:24 陈小东 阅读(784) | 评论 (0)编辑 收藏

用拦截器实现登录验证功能AuthorizationInterceptor
package com.interceptor;   
  
import com.opensymphony.xwork2.ActionInvocation;   
import com.opensymphony.xwork2.interceptor.*;   
import com.opensymphony.xwork2.*;   
import java.util.*;   
/**  
 * 
@author http://xp9802.iteye.com/  
 
*/
  
public class AuthorizationInterceptor extends AbstractInterceptor {   
    
private String ignoreActions;   
  
    
// ignoreActions属性的getter方法   
    public String getIgnoreActios() {   
        
return ignoreActions;   
    }
   
  
    
// ignoreActions属性的setter方法   
    public void setIgnoreActions(String ignoreActions) {   
        
this.ignoreActions = ignoreActions;   
    }
   
  
    @Override  
    
public String intercept(ActionInvocation invocation) throws Exception {   
        ActionContext ctx 
= invocation.getInvocationContext();   
  
        Map session 
= ctx.getSession();   
        String user 
= (String) session.get("username");   
  
        
boolean ignore = false;   
        String currentAction 
= invocation.getProxy().getActionName();   
        String[] actions 
= ignoreActions.split(",");   
  
        
for (String action : actions) {   
            
if (currentAction.matches(action.trim())) {   
                ignore 
= true;   
                
break;   
            }
   
        }
   
  
        
if (user != null || ignore == true{   
  
            
return invocation.invoke();   
        }
 else {   
            
return Action
<interceptors>    
    
<interceptor name="authorization" class="com.interceptor.AuthorizationInterceptor" />    
    
<interceptor-stack name="myStack">    
        
<interceptor-ref name="authorization">    
            
<param name="ignoreActions"> validate_code,register.*,.*login.*,upload,connector</param>    
     
</interceptor-ref> <interceptor-ref name="defaultStack" />   
</interceptor-stack>    
lt;/interceptors>    
<default-interceptor-ref name="myStack"/>  
.LOGIN;   
        }
   
  
    }
   
}
  

在struts.xml文件里面配置该拦截器:


posted @ 2011-11-22 09:23 陈小东 阅读(755) | 评论 (0)编辑 收藏

     摘要:   阅读全文

posted @ 2011-11-21 09:36 陈小东 阅读(212) | 评论 (0)编辑 收藏

1. BIRT Project
BIRT报表是一款非常流行的开源报表开发工具。拥有和Dreamweaver一般的操作界面,可以像画table一样画报表,生成图片,导出Excel,html分页样样齐全,样式和script设置简单。

2. Pentaho
Pentaho Report Designer是一款所见即所得的开源报表设计工具。在设计报表的时候,用户可以随意拖放和设置各种报表的控件,还可以快速方便地设置报表的数据来源。在报表的设计过程中,用户可以随时预览报表的结果。

3. OpenRPT
OpenRPT支持各种平台PostgreSQL的最佳化的图形化界面的SQL报表撰写。

4. OpenReports
OpenReports 提供基于web 的灵活报表解决方案,支持 PDF,HTML 和XLS 报表格式,基于WebWork,Hibernate 和 Velocity 开发完成,并且还提供一个整合了Tomcat 的OpenReports-Tomcat 文件下载。使用Java进行开发,JasperReports 作为报表引擎。

5. FreeReportBuilder
FreeReportBuilder是一个Java报表工具,可以与任何数据库正常工作,只需要有一个JDBC驱动程序。

6. JMagallanes
JMagallanes是一个开源的使用Java/J2EE开发的Olap和动态报表应用程序。JMagallanes结合了静态报表(基于JasperReports),Swing pivot表格(用于OLAP分析),和图表(基于JFreeChart)。它可从多种数据源(如:SQL,Excel,XML和其它)读取数据并可生成多种输出如:PDF,XML,应用程序特殊文件用于将来报表的脱机查看。

7. ART – A lightweight reporting solution
ART是一个轻量级的,多平台基于web的报表引擎。定制容易,支持图形报表,支持通过插件把结果导出为各种格式。

8. DataVision
DataVision是一个用Java编写的类似于Crystal Reports的报表工具。它支持多种数据源(JDBC, 文本文件) ,输出格式有HTML, XML, PDF, LaTeX, 逗号或tab分隔的数据文件, 和DocBook。它让你用一个支持拖放操作的GUI设计报表,报表描述存储为XML。

9. The Wabit – Open Source Reporting Tool
Wabit 是一个跨平台开源的报表工具,提供了一个GUI程序和可嵌入式的接口。

10. Rlib
RLIB是一个基于XML的报表引擎,可以生成PDF,HTML,CSV,文本格式

11. JavaEye Reporting Tool – JERT
JERT是一个开放源代码的,基于web的,数据库报表工具,它能够让你不需要编程而能创建各种灵活的报表。

12. iReport
iReport是一个能够创建复杂报表的开源项目,并且它能调用JasperReports库应用于任何一种java应用程序,使用纯Java编写,拥有非常丰富的图形界面。

posted @ 2011-11-21 09:34 陈小东 阅读(398) | 评论 (0)编辑 收藏

     摘要:   阅读全文

posted @ 2011-11-19 11:54 陈小东 阅读(168) | 评论 (0)编辑 收藏

     摘要:   阅读全文

posted @ 2011-11-18 15:42 陈小东 阅读(293) | 评论 (0)编辑 收藏

1) 在Action实现类方面的对比:Struts 1要求Action类继承一个抽象基类;Struts 1的一个具体问题是使用抽象类编程而不是接口。Struts 2 Action类可以实现一个Action接口,也可以实现其他接口,使可选和定制的服务成为可能。Struts 2提供一个ActionSupport基类去实现常用的接口。即使Action接口不是必须实现的,只有一个包含execute方法的POJO类都可以用作Struts 2的Action。
2) 线程模式方面的对比:Struts 1 Action是单例模式并且必须是线程安全的,因为仅有Action的一个实例来处理所有的请求。单例策略限制了Struts 1 Action能做的事,并且要在开发时特别小心。Action资源必须是线程安全的或同步的;Struts 2 Action对象为每一个请求产生一个实例,因此没有线程安全问题。
3) Servlet依赖方面的对比:Struts 1 Action依赖于Servlet API,因为Struts 1 Action的execute方法中有HttpServletRequest和HttpServletResponse方法。Struts 2 Action不再依赖于Servlet API,从而允许Action脱离Web容器运行,从而降低了测试Action的难度。 当然,如果Action需要直接访问HttpServletRequest和HttpServletResponse参数,Struts 2 Action仍然可以访问它们。但是,大部分时候,Action都无需直接访问HttpServetRequest和HttpServletResponse,从而给开发者更多灵活的选择。
4) 可测性方面的对比:测试Struts 1 Action的一个主要问题是execute方法依赖于Servlet API,这使得Action的测试要依赖于Web容器。为了脱离Web容器测试Struts 1的Action,必须借助于第三方扩展:Struts TestCase,该扩展下包含了系列的Mock对象(模拟了HttpServetRequest和HttpServletResponse对象),从而可以脱离Web容器测试Struts 1的Action类。Struts 2 Action可以通过初始化、设置属性、调用方法来测试。
5) 封装请求参数的对比:Struts 1使用ActionForm对象封装用户的请求参数,所有的ActionForm必须继承一个基类:ActionForm。普通的JavaBean不能用作ActionForm,因此,开发者必须创建大量的ActionForm类封装用户请求参数。虽然Struts 1提供了动态ActionForm来简化ActionForm的开发,但依然需要在配置文件中定义ActionForm;Struts 2直接使用Action属性来封装用户请求属性,避免了开发者需要大量开发ActionForm类的烦琐,实际上,这些属性还可以是包含子属性的Rich对象类型。如果开发者依然怀念Struts 1 ActionForm的模式,Struts 2提供了ModelDriven模式,可以让开发者使用单独的Model对象来封装用户请求参数,但该Model对象无需继承任何Struts 2基类,是一个POJO,从而降低了代码污染。
6) 表达式语言方面的对比:Struts 1整合了JSTL,因此可以使用JSTL表达式语言。这种表达式语言有基本对象图遍历,但在对集合和索引属性的支持上则功能不强;Struts 2可以使用JSTL,但它整合了一种更强大和灵活的表达式语言:OGNL(Object Graph Notation Language),因此,Struts 2下的表达式语言功能更加强大。
7) — 绑定值到视图的对比:Struts 1使用标准JSP机制把对象绑定到视图页面;Struts 2使用“ValueStack”技术,使标签库能够访问值,而不需要把对象和视图页面绑定在一起。
8) 类型转换的对比:Struts 1 ActionForm 属性通常都是String类型。Struts 1使用Commons-Beanutils进行类型转换,每个类一个转换器,转换器是不可配置的;Struts 2使用OGNL进行类型转换,支持基本数据类型和常用对象之间的转换。
9) 数据校验的对比:Struts 1支持在ActionForm重写validate方法中手动校验,或者通过整合Commons alidator框架来完成数据校验。Struts 2支持通过重写validate方法进行校验,也支持整合XWork校验框架进行校验。
10) Action执行控制的对比:Struts 1支持每一个模块对应一个请求处理(即生命周期的概念),但是模块中的所有Action必须共享相同的生命周期。Struts 2支持通过拦截器堆栈(Interceptor Stacks)为每一个Action创建不同的生命周期。开发者可以根据需要创建相应堆栈,从而和不同的Action一起使用。
11) 捕获输入:Struts1 使用ActionForm对象捕获输入。所有的ActionForm必须继承一个基类。因为其他JavaBean不能用作ActionForm,开发者经常创建多余的类捕获输入。动态Bean(DynaBeans)可以作为创建传统ActionForm的选择,但是,开发者可能是在重新描述(创建)已经存在的JavaBean(仍然会导致有冗余的javabean)。Struts 2直接使用Action属性作为输入属性,消除了对第二个输入对象的需求。输入属性可能是有自己(子)属性的rich对象类型。Action属性能够通过 web页面上的taglibs访问。Struts2也支持ActionForm模式。rich对象类型,包括业务对象,能够用作输入/输出对象。这种 ModelDriven 特性简化了taglib对POJO输入对象的引用。

posted @ 2011-11-17 09:14 陈小东 阅读(57488) | 评论 (17)编辑 收藏

     摘要:   阅读全文

posted @ 2011-11-16 09:03 陈小东 阅读(402) | 评论 (0)编辑 收藏

内连接:INNER  JOIN或者JOIN,把两个表中数据对应的数据查出来。
外连接:OUTER  JOIN,以某个表为基础把对应数据查出来,分为左外连接和右外连接。
左外连接:LEFT  JOIN或者LEFT  OUTER  JOIN,以某个表为基础把对应数据查出来。
右外连接:RIGHT  JOIN或者RIGHT  OUTER  JOIN,以某个表为基础把对应数据查出来。
全连接:FULL  JOIN,以多个表为基础

posted @ 2011-11-15 09:22 陈小东 阅读(136) | 评论 (0)编辑 收藏

内连接:INNER  JOIN或者JOIN,把两个表中数据对应的数据查出来。
外连接:OUTER  JOIN,以某个表为基础把对应数据查出来,分为左外连接和右外连接。
左外连接:LEFT  JOIN或者LEFT  OUTER  JOIN,以某个表为基础把对应数据查出来。
右外连接:RIGHT  JOIN或者RIGHT  OUTER  JOIN,以某个表为基础把对应数据查出来。
全连接:FULL  JOIN,以多个表为基础

posted @ 2011-11-15 09:22 陈小东 阅读(1775) | 评论 (0)编辑 收藏

仅列出标题
共4页: 上一页 1 2 3 4 下一页 

posts - 34, comments - 38, trackbacks - 0, articles - 0

Copyright © 陈小东