肝 hibernate 配置and增删改查 and 测试

  已经通宵三天撸代码了,现在的我已经养成晚上修仙写代码的节奏了.....最近 刚刚复习到了 hibernate 谈谈 这篇文章就谈谈我对这货的理解吧.

在看这篇文章之前希望你 知道sessionfactory 和session 还有 transaction(事物) 诶嘿不造的可以去看看http://blog.csdn.net/u012377333/article/details/48086193

   OK正题开始 步骤 我们需要一个可以持久化的bean类 还有它的附属映射 hbm.xml文件 以及dao(重要)  and 测试类 

首先开始是bean类代码如下:

  

package qy.java.bean;

public class Userbean {
    private int id;
    private String username;
    private String password;

    public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } @Override public String toString() { return "Userbean{" + "id=" + id + ", username='" + username + '\'' + ", password='" + password + '\'' + '}'; } }

其次是他的映射文件

  

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="qy.java.bean">
    <class name="Userbean" table="x_user">
        <id name="id" type="int" column="id">
            <generator class="native"/>
        </id>
        <property name="username" type="string" column="username" length="20"/>
        <property name="password" type="string" column="password" length="20"/>
    </class>
</hibernate-mapping>

这里要说一个 在主配置文件里面我没有配置自动建表的那货= = 所以我是直接手动 建表 有兴趣的同学可以自己去配置

  然后是dao类   里面包括增删改查 还有一个记录数是买4送一吧,哦对了 我这种初始方法是比较老的一种方法 新的初始化方法在下面

package qy.java.dao;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.query.Query; import qy.java.bean.Userbean; import java.util.List; public class Userdao { private static SessionFactory sf; static { Configuration cfg = new Configuration().configure("hibernate.cfg.xml"); sf = cfg.buildSessionFactory();// 获得会话工厂  } // 增加 public void add(Userbean user) { // 读配置文件,会 Session s = sf.openSession(); Transaction t = null; try { t = s.beginTransaction(); s.save(user); //持久化 对象 t.commit(); //提交 } catch (Exception e) { t.rollback(); //回滚 throw new RuntimeException(e); } finally { s.close(); } } // 更新 public void update(Userbean user) { // 读配置文件,会 Session s = sf.openSession(); Transaction t = null; try { t = s.beginTransaction(); s.update(user); // s.update("username", user);  t.commit(); } catch (Exception e) { t.rollback(); throw new RuntimeException(e); } finally { s.close(); } } //删除 public void delete(int id) { // 读配置文件,会 Session s = sf.openSession(); Transaction t = null; try { t = s.beginTransaction(); // User user = (User) s.get(User.class, id); Userbean user = new Userbean(); user.setId(id); s.delete(user); t.commit(); } catch (Exception e) { t.rollback(); throw new RuntimeException(e); } finally { s.close(); } } //查询所有 public List<Userbean> findALL() { // 读配置文件,会 Session s = sf.openSession(); List<Userbean> list = null; try { list = s.createQuery("FROM Userbean").list(); /*Criteria c = s.createCriteria(User.class); list = c.list();*/ } catch (Exception e) { throw e; } finally { s.close(); } return list; }        // 查询总记录数 public long findUserCount() { //int double ,integer Double char Charset Session s = sf.openSession(); Long count = null; try { count = (Long) s.createQuery("SELECT COUNT(*) FROM Userbean ")//  .uniqueResult(); } catch (Exception e) { throw e; } finally { s.close(); } return count; } }

这个是新的初始化方法 

package qy.java.dao;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import qy.java.bean.Userbean; public class Foxdao { private static SessionFactory sf; static { try { Configuration configuration = new Configuration(); configuration.configure(); sf = configuration.buildSessionFactory(); } catch (Throwable ex) { throw new ExceptionInInitializerError(ex); } } // 增加 public void add(Userbean user) { // 读配置文件,会 Session s = sf.openSession(); Transaction t = null; try { t = s.beginTransaction(); s.save(user); //持久化 对象 t.commit(); //提交 } catch (Exception e) { t.rollback(); //回滚 throw new RuntimeException(e); } finally { s.close(); } } }

然后了是测试 方法= = 仁慈的我还给发测试.....

package test.qy.java.dao; 

import org.junit.Test; 
import org.junit.Before; 
import org.junit.After;
import qy.java.bean.Userbean;
import qy.java.dao.Userdao; import java.util.Iterator; import java.util.List; /** * Userdao Tester. * * @author <Authors name> * @since <pre>���� 20, 2017</pre> * @version 1.0 */ public class UserdaoTest { @Before public void before() throws Exception { } @After public void after() throws Exception { } /** * * Method: add(Userbean user) * */ @Test public void testAdd() throws Exception { Userbean user = new Userbean(); user.setPassword("wqerwqer"); user.setUsername("zhangsan"); new Userdao().add(user); } @Test public void updel(){ Userbean userbean = new Userbean(); userbean.setId(1); userbean.setUsername("滑稽"); userbean.setPassword("10086"); new Userdao().update(userbean); } @Test public void delet(){ new Userdao().delete(2); } @Test public void file(){ List<Userbean> list =new Userdao().findALL(); Iterator<Userbean> it = list.iterator(); Userbean user = null; while (it.hasNext()){ user = it.next(); System.out.println(user.getUsername()); } } @Test public void testFindAllUserCount(){ long count =new Userdao().findUserCount(); System.out.println(count); } } 

增删改查虽然简单 但是这些都是基础 就像 功夫里面的蹲马步 跑步一样 灵活运用 才能发挥他们真正的实力 相互之间的配合 结合自己的所需才能 实现作用 最大化..

  emmm写完了 刚开始搭建环境的时候出现 hibernate的不兼容我这个 jdk1.7原因是hibernate的版本太高了 = =然后我又懒 所以我就去下了一个1.8明明 十多分钟 能搞定的事情用了 一个多小时...气死欧蕾.

  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值