Hibernate入门(IDEA下自动生成映射文件及实体类)
1.Hibernate開發步驟
1.創建Hibernate配置文件 2.創建持久化類 3.創建對象-關系映射文件 4.通過Hibernate API編寫訪問數據庫的代碼2.創建一個hibernate項目(IntelliJ IDEA下演示)
后續需要連接數據庫,手動導入這兩個包
3.配置文件
修改hibernate.cfg.xml
<?xml version='1.0' encoding='utf-8'?> <!DOCTYPE hibernate-configuration PUBLIC"-//Hibernate/Hibernate Configuration DTD//EN""http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration><session-factory> ?<!-- 配置連接數據庫的基本信息 --><property name="connection.driver_class">com.mysql.jdbc.Driver</property><property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property><!--數據庫用戶名配置--><property name="connection.username">root</property><!--數據庫密碼配置--><property name="connection.password">root</property> ?<!-- 配置 hibernate 的基本信息 --><!-- hibernate 所使用的數據庫方言 --><property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property><!--56--><!-- 執行操作時是否在控制臺打印 SQL --><property name="show_sql">true</property> ?<!-- 是否對 SQL 進行格式化 --><property name="format_sql">true</property> ?<!-- 指定自動生成數據表的策略 --><property name="hbm2ddl.auto">update</property><!-- 后面的這兩行為后續自動生成實體類及配置文件時自動生成的--><mapping class="com.yfy.hibernate.entity.NewsEntity"/><mapping resource="com/yfy/hibernate/entity/NewsEntity.hbm.xml"/> ?</session-factory> </hibernate-configuration>生成表的策略:
-
create:會根據*.hbm.xml文件來生成數據表,但是每次運行都會刪除上一次的表,重新生成表
-
create-drop:會根據*.hbm.xml文件來生成數據表,但是SessionFactory一關閉,表就自動刪除
-
update:最常用的屬性,會根據*.hbm.xml文件生成表,但若.hbm.xml文件和數據庫中對應的數據表的結構不同,Hibernate將更新數據表結構
-
validate:會和數據庫中的表進行比較,若*.hbm.xml文件中的列在數據表中不存在,則拋出異常
4.配置數據庫
(1)點擊Database
(2)選擇數據庫
?
(3)配置數據庫后測試連接是否成功
?
(4)表結構如下
(5)自動生成hibernate實體類和映射文件
?
(5)生成的實體類和配置文件如下
創建持久化java類
1.提供一個無參構造器 2.提供一個標識屬性 3.為類的持久化類字段聲明訪問方法(get/set) 4.使用非final類(在運行時生成代理 cglib) 5.重寫equals和hashCode方法NewsEntity.java
@Entity @Table(name = "news", schema = "hibernate") public class NewsEntity { ?private int id;private String title;private String author;private Date data; ?@Id@Column(name = "id")public int getId() {return id;} ?public void setId(int id) {this.id = id;} ?@Basic@Column(name = "title")public String getTitle() {return title;} ?public void setTitle(String title) {this.title = title;} ?@Basic@Column(name = "author")public String getAuthor() {return author;} ?public void setAuthor(String author) {this.author = author;} ?@Basic@Column(name = "data")public Date getData() {return data;} ?public void setData(Date data) {this.data = data;} ?@Overridepublic boolean equals(Object o) {if (this == o) return true;if (o == null || getClass() != o.getClass()) return false;NewsEntity that = (NewsEntity) o;return id == that.id &&Objects.equals(title, that.title) &&Objects.equals(author, that.author) &&Objects.equals(data, that.data);} ?@Overridepublic int hashCode() { ?return Objects.hash(id, title, author, data);} ?@Overridepublic String toString() {return "NewsEntity{" +"id=" + id +", title='" + title + '\'' +", author='" + author + '\'' +", data=" + data +'}';} }NewsEntity.hbm.xml
<?xml version='1.0' encoding='utf-8'?> <!DOCTYPE hibernate-mapping PUBLIC"-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping> ?<class name="com.yfy.hibernate.entity.NewsEntity" table="news" schema="hibernate"><id name="id" column="id"/><property name="title" column="title"/><property name="author" column="author"/><property name="data" column="data"/></class> </hibernate-mapping>(6)編寫測試類
HibernateTest.java
public class HibernateTest { ?private Session getSession() { ?//1. 創建一個 SessionFactory 對象SessionFactory sessionFactory = null; ?//1). 創建 Configuration 對象: 對應 hibernate 的基本配置信息和 對象關系映射信息Configuration configuration = new Configuration().configure(); ?//4.0 之前這樣創建 // sessionFactory = configuration.buildSessionFactory(); ?//2). 創建一個 ServiceRegistry 對象: hibernate 4.x 新添加的對象//hibernate 的任何配置和服務都需要在該對象中注冊后才能有效.ServiceRegistry serviceRegistry =new ServiceRegistryBuilder().applySettings(configuration.getProperties()).buildServiceRegistry(); ?//3).sessionFactory = configuration.buildSessionFactory(serviceRegistry); ?//2. 創建一個 Session 對象return sessionFactory.openSession();} ?@Testpublic void testGet() { ?Session session = getSession();NewsEntity newsEntity = (NewsEntity) session.get(NewsEntity.class, 2);System.out.println(newsEntity);session.close();} ?@Testpublic void testAdd() { ?Session session = getSession();//3. 開啟事務Transaction transaction = session.beginTransaction(); ?//4. 執行保存操作NewsEntity newsEntity = new NewsEntity(); // ? ? ? newsEntity.setId(2);newsEntity.setTitle("java語句很強嗎");newsEntity.setAuthor("hello123");newsEntity.setData(new Date());session.save(newsEntity); ?//5. 提交事務transaction.commit(); ?//6. 關閉 Sessionsession.close();} }5.具體類介紹
Configuration類
負責管理Hibernate的配置信息、包括如下內容:
-
Hibernate運行的底層信息:數據庫的URL、用戶名、密碼、JDBC驅動類,數據庫Dialect,數據庫連接池等(hibernate.cfg.xml)
-
持久化類與數據庫的映射關系(*.hbm.xml)
創建Configuration的兩種方式
//屬性文件(hibernate.properties) Configuration cfg=new Configuration(); ? //xml文件(hibernate.cfg.xml) Configuration cfg=new Configuration().configure()'//還支持帶參數的訪問 File file=new File("hibernate.xml"); Configuration cfg=new Configuration().configure(file);SessionFactory接口
-
針對單個數據庫映射關系經過編譯后的內存鏡像,是線程安全的
-
SessionFactory對象一旦構造完畢,即被賦予特定的配置信息
-
SessionFactory是生成Session的工廠
-
Hibernate4新增了一個ServiceRegistry接口,所有基于Hibernate的配置或者服務都必須統一向這個ServiceRegisty注冊后才能生效
Session接口
Session是應用程序與數據庫之間交互操作的一個單線程對象,是Hibernate運作的中心,所有持久化對象都必須在session的管理下才可以進行持久化操作。
Session對象有一個一級緩存,顯式執行flush之前,所有的持久層操作的數據都緩存在session對象中。
總結
以上是生活随笔為你收集整理的Hibernate入门(IDEA下自动生成映射文件及实体类)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 基于JWT的Token认证机制实现
- 下一篇: Hibernate之Session解析