Hibernate HelloWorld

Hibernate版本_hibernate-release-4.3.8.Finaljava

下載地址http://hibernate.org/mysql

1.新建JavaWeb項目sql

2.添加所須要的jar包數據庫

  將hibernate-release-4.3.8.Final\lib\required下的全部文件添加到build path中便可api

  文件列表以下:session

antlr-2.7.7.jar
dom4j-1.6.1.jar
hibernate-commons-annotations-4.0.5.Final.jar
hibernate-core-4.3.8.Final.jar
hibernate-jpa-2.1-api-1.0.0.Final.jar
jandex-1.1.0.Final.jar
javassist-3.18.1-GA.jar
jboss-logging-3.1.3.GA.jar
jboss-logging-annotations-1.2.0.Beta1.jar
jboss-transaction-api_1.2_spec-1.0.0.Final.jar

3.編寫配置文件hibernate.cfg.xmlapp

  在src目錄下新建文件hibernate.cfg.xmldom

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

    <session-factory>

        <!-- Database connection settings -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost/hibernate</property>
        <property name="connection.username">root</property>
        <property name="connection.password">mysql</property>

        <!-- JDBC connection pool (use the built-in) -->
        <property name="connection.pool_size">1</property>

        <!-- SQL dialect -->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>

        <!-- Enable Hibernate's automatic session context management -->
        <property name="current_session_context_class">thread</property>

        <!-- Disable the second-level cache  -->
        <property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property>

        <!-- Echo all executed SQL to stdout -->
        <property name="show_sql">true</property>

        <!-- Drop and re-create the database schema on startup-->
        <property name="hbm2ddl.auto">update</property> 
        
        <property name="javax.persistence.validation.mode">none</property> 
        
        <mapping class="com.ssh.vo.User"/>
    </session-factory>

</hibernate-configuration>

4.建立實體類ssh

 1 /**----------------------------------------------------------+
 2  +   PGM-ID  :   User.java
 3  +   Author  :   H.Liu
 4  +   Date    :   2015年3月21日 下午5:47:04
 5  +   Function:   經過註解進行映射   
 6  +               
 7  +-----------------------------------------------------------*/
 8 package com.ssh.vo;
 9 
10 import java.io.Serializable;
11 
12 import javax.persistence.Column;
13 import javax.persistence.Entity;
14 import javax.persistence.GeneratedValue;
15 import javax.persistence.Id;
16 import javax.persistence.Table;
17 
18 @Entity
19 @Table(name="user")
20 public class User implements Serializable {
21     
22     //@GeneratedValue主鍵生成策略由hibernate本身決定
23     @Id@GeneratedValue
24     private int id;
25     private String password;
26     @Column(name="username")
27     private String username;
28 
29     public User(){
30         
31     }    
32     
33     public User(String username,String password) {
34         this.username = username;
35         this.password = password;
36     }
37 
38     public User(int id, String password, String username) {
39         super();
40         this.id = id;
41         this.password = password;
42         this.username = username;
43     }
44 
45     public int getId() {
46         return id;
47     }
48 
49     public String getPassword() {
50         return password;
51     }
52 
53     public String getUsername() {
54         return username;
55     }
56 
57     public void setId(int id) {
58         this.id = id;
59     }
60 
61     public void setPassword(String password) {
62         this.password = password;
63     }
64     
65     public void setUsername(String username) {
66         this.username = username;
67     }
68     
69 }
View Code

 

5.編寫數據操做類ide

/**----------------------------------------------------------+
 +   PGM-ID  :   UserDaoImpl.java
 +   Author  :   H.Liu
 +   Date    :   2015年3月22日 上午11:50:26
 +   Function:   
 +               
 +-----------------------------------------------------------*/
package com.ssh.dao;

import java.io.Serializable;
import java.util.Iterator;
import java.util.List;

import org.hibernate.HibernateException;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;

import com.ssh.util.HibernateUtil;
import com.ssh.vo.User;

public class UserDaoImpl {
    
    // 向數據庫的添加記錄
    public int add(User user){
        
        SessionFactory sessionFactory = HibernateUtil.getSessionFactory();//得到工廠類
        
        Session session = sessionFactory.openSession();//取得session
        
        Transaction  tx = null;//定義事務
        try{
            tx = session.beginTransaction();
            Serializable i = session.save(user);
            System.out.println(i);
            tx.commit();//提交
        } catch (HibernateException e){
            if(tx!=null) tx.rollback();
            e.printStackTrace();
        } finally{
            session.close();
        }
        
        return 0;
    }
    
    // 得到表中全部記錄
    public void list(){
        SessionFactory sessionFactory = HibernateUtil.getSessionFactory();//得到工廠類
        
        Session session = sessionFactory.openSession();//取得session
        
        Transaction  tx = null;//定義事務
        try{
            tx = session.beginTransaction();
            
            //經過HQL進行查詢
            /**
            List<?> users = session.createQuery("select new User(u.id, u.username, u.password) from com.ssh.vo.User u").list();
            */
            SQLQuery query = session.createSQLQuery("select id,username,password from user");
            query.addEntity(User.class);
            List<?> users = query.list();
            User user = null;
            Iterator<?> iterator =users.iterator();
            while(iterator.hasNext()){
                user= (User) iterator.next();
                System.out.println("| " +user.getId() + "|" + user.getUsername() +"|" + user.getPassword() + " |");
            }
            tx.commit();//提交
        } catch (HibernateException e){
            if(tx!=null) tx.rollback();
            e.printStackTrace();
        } finally{
            session.close();
            sessionFactory.close();
        }
            
    }
    
    //更新表中的數據
    public void update(User user){
        SessionFactory sessionFactory = HibernateUtil.getSessionFactory();//得到工廠類
        
        Session session = sessionFactory.openSession();//取得session
        
        Transaction  tx = null;//定義事務
        try{
            tx = session.beginTransaction();
            session.update(user);

            tx.commit();//提交
        } catch (HibernateException e){
            if(tx!=null) tx.rollback();
            e.printStackTrace();
        } finally{
            session.close();
            sessionFactory.close();
        }      
    }
    
    //刪除表中的數據
    public void delete(User user){
        SessionFactory sessionFactory = HibernateUtil.getSessionFactory();//得到工廠類
        
        Session session = sessionFactory.openSession();//取得session
        
        Transaction  tx = null;//定義事務
        try{
            tx = session.beginTransaction();
            session.delete(user);

            tx.commit();//提交
        } catch (HibernateException e){
            if(tx!=null) tx.rollback();
            e.printStackTrace();
        } finally{
            session.close();
            sessionFactory.close();
        }      
    }
}
/**----------------------------------------------------------+
 +   PGM-ID  :   HibernateUtil.java
 +   Author  :   H.Liu
 +   Date    :   2015年3月21日 下午5:54:53
 +   Function:   取得SessionFactory
 +               
 +-----------------------------------------------------------*/
package com.ssh.util;

import org.hibernate.SessionFactory;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;

public class HibernateUtil {
    private static final SessionFactory sessionFactory = buildSessionFactory();  
    
    private static SessionFactory buildSessionFactory() {  
        try {  
            Configuration cfg = new Configuration().configure();  
            StandardServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder()  
                                .applySettings(cfg.getProperties()).build();  
            SessionFactory sessionFactory = cfg.buildSessionFactory(serviceRegistry);  
            return sessionFactory;  
              
        }  
        catch (Throwable ex) {  
            System.err.println("Initial SessionFactory creation failed." + ex);  
            throw new ExceptionInInitializerError(ex);  
        }  
    }  
  
    public static SessionFactory getSessionFactory() {  
        return sessionFactory;  
    }

}

 

6.編寫測試類

/**----------------------------------------------------------+
 +   PGM-ID  :   UserManager.java
 +   Author  :   H.Liu
 +   Date    :   2015年3月21日 下午5:53:15
 +   Function:   
 +               
 +-----------------------------------------------------------*/
package com.ssh.dao;

import com.ssh.vo.User;

public class UserManager {

    public static void main(String[] args) {

        UserDaoImpl userDaoImpl = new UserDaoImpl();
        User user = new User("sa", "sa");
        userDaoImpl.add(user);
        userDaoImpl.list();
        userDaoImpl.update(new User(1, "ss", "ss"));
        userDaoImpl.delete(new User(1, "ss", "ss"));
    }

}
相關文章
相關標籤/搜索