Hibernate(一)
阿新 • • 發佈:2018-05-18
導入 根據 reat session 取值 eat color pro sql
什麽是hibernate?
hibernate是一個orm框架,實現了對JDBC的封裝。通過xml文件來實現類和表之間的映射,這樣就可以使用操作對象的方式來操作數據庫。
官網:http://hibernate.org/
這裏使用最新的5.3版本,下載到本地。
hibernate框架搭建:
1.導入包 下載後將lib/required文件夾中的jar包以及mysql數據庫的驅動jar包(mysql-connector-java-5.1.46.jar)導入到項目中
2.寫全局配置文件 創建hibernate.cfg.xml
<?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> <!--數據庫驅動類全稱 --> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <!--數據庫url地址 --> <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/david2018_db?characterEncoding=UTF-8</property> <!--用戶名 --> <propertyname="hibernate.connection.username">root</property> <!--密碼 --> <property name="hibernate.connection.password">1234</property> <!--方言 --> <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property> <!--執行DDL的類別: create:每次都刪除新建 update:存在就修改,不存在就新建 --> <property name="hibernate.hbm2ddl.auto">update</property> <!--是否顯示SQL語句 --> <property name="hibernate.show_sql">true</property> <!--是否格式化SQL語句 --> <property name="hibernate.format_sql">true</property> <!-- 啟用getCurrentSession,默認未啟用 --> <property name="hibernate.current_session_context_class">thread</property> <!--基於xml映射文件: 映射文件加載。路徑 --> <mapping resource="com/hibernate/domain/User.hbm.xml"></mapping> </session-factory> </hibernate-configuration>
3.實體類
package com.hibernate.domain; public class User { private int UserId; private String UserName; private String PassWord; private int Age; private String Sex; public User(){ } public User(String userName,String password,int age,String sex){ this.UserName = userName; this.PassWord = password; this.Age = age; this.Sex = sex; } public int getUserId() { return UserId; } public void setUserId(int UserId) { this.UserId = UserId; } 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; } public int getAge() { return Age; } public void setAge(int Age) { this.Age = Age; } public String getSex() { return Sex; } public void setSex(String Sex) { this.Sex = Sex; } }
4.編寫對應實體類的User.hbm.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping SYSTEM "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd" > <!--映射標簽 package:內部類的所在的包名 --> <hibernate-mapping package="com.hibernate.dao"> <!--需要設置的映射類:設置該類對應的表 --> <!--屬性: name:類名 table:表名 --> <class name="com.hibernate.domain.User" table="User"> <!--id:主鍵,name:屬性名稱,column:字段名稱 --> <id name="UserId" column="UserId"> <!--generator:主鍵生成策略 class:標記主鍵如何生成 取值: 1、native:自動增長,會根據當前的數據庫自動切換 2、identity:mySQL的自增策略 3、sequence:Oracle的自增標記 4、uuid:32位字符串 5、assigned:自定義字符串 6、foreign:外鍵 7、increment:自己維護自增關系 --> <generator class="native"/> </id> <!--配置屬性對應的字段 --> <property name="UserName" column="UserName"/> <property name="PassWord" column="PassWord"/> <property name="Age" column="Age"/> <property name="Sex" column="Sex"/> </class> </hibernate-mapping>
5.測試
import com.hibernate.domain.User; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; public class Main { public static void main(String[] args) { // 加載配置文件 Configuration configuration = new Configuration().configure(); // 創建Session工廠 SessionFactory sessionFactory = configuration.buildSessionFactory(); // 創建Session對象 Session session = sessionFactory.openSession(); // 開啟事務 Transaction tx = session.beginTransaction(); User user = new User("測試", "666666",18,"男"); //執行保存 session.save(user); //提交事務 tx.commit(); session.close(); sessionFactory.close(); } }
這樣就可以像表中插入一條數據。
Hibernate(一)