首先建立表t_user 然后利用工具自动生成实体类middlegen build file
添加hibernate的jar包,建立HiberantesessionFactory类,里面的静态方法可以帮我们获取链接,可以直接让myeclipse生成
应该知道,在真正的开发里面,要么是从表直接映射出实体类,要么从实体类生成表,不会分别设计表和类然后再去映射,那样浪费时间 我的表很简单,只有三个字段 id name passwd
在生成的时候 id指定为native 自动递增 只不过生成的实体类名无法修改,只能是TUser 我们把实体类生成在com.model.vo包下
好了,下面来配置 struts2+hibernate环境,直接把struts2的jar文件复制到lib目录下,就会自动生成web app库,接着配置web.xml,在这之前,比较好的习惯是检查一下struts2.xml的环境是否配置成功,在struts.xml里面配置一个hello action ,不做任何处理,看看能否成功访问,我之前就是忘记配置web.xml了,因为以前都是直接用myeclipse的内置的struts2功能,他会自动帮你配置好web.xml,所以我都快忘记了要配置web.xml了,不要犯低级错误。。
下面开始建立dao层 先看看有哪些包
这里是dao的接口定义
package com.model.dao;import com.model.vo.TUser;public interface IUserDAO { public void save(TUser u); public void delete(TUser u); public void update(TUser u); public TUser find(TUser u);}这是dao的实现层,在测试的时候出现过一个错误,就是Transaction not successfully start ,原来是把s.beginTransaction()写成了 s.getTransaction(),还有别忘记添加数据库驱动了
@Override public void save(TUser u) { // TODO Auto-generated method stub //jdbc hiberante mybatis Session s = HibernateSessionFactory.getSession(); Transaction t = s.beginTransaction(); s.save(u); t.commit(); // s.flush(); s.close(); }这个数据库连接对象session,一开始有2个想法,第一个是放在类的成员变量里面,但是考虑到每次执行方法都要关闭数据库连接,所以索性在每个方法里面定义连接对象算了
下面是服务层,也可以叫做代理层
PRivate IUserDAO dao = null; public UserService() {//提供一个注入dao的方法 // TODO Auto-generated constructor stub this.dao = new UserDAOImpl(); } @Override public void save(TUser u) { // TODO Auto-generated method stub dao.save(u); }再次建立一个ServiceFactory类,降低代码耦合度
package com.model.service;import com.model.dao.IUserDAO;public class ServiceFactory { public static IUserDAO getInstance(){ return new UserService(); }}dao层依靠hibernate框架很容易就实现了,接下来我们测试一下
package com.test;import static org.junit.Assert.*;import org.junit.Test;import com.model.dao.*;import com.model.vo.*;public class TestDAO { @Test public void test() { TUser a = new TUser(); a.setId(1); a.setName("huang"); a.setPasswd("sdf"); UserDAOImpl d = new UserDAOImpl(); d.save(a); }}DAO层没有问题再进行action的开发,这叫做步步为营,确保自己当前的代码都是没有问题的,再进行下一步的开发,心里比较有底比较好。。
新闻热点
疑难解答