在Hibernate3.2中,引進了Java5的新特性,就是注釋配置,替代了我們以前用的*.hbm.xml配置文件,只需在實體類中進行相應的配置來完成 Hibernate的映射。
正如其他的ORM工具,Hibernate同樣需要元數據來控制在不同數據表達形式之間的轉化. 在Hibernate 2.x里,多數情況下表示映射關系的元數據保存在XML文本文件中. 還有一種方式就是Xdoclet,它可以在編譯時利用Javadoc中的源碼注釋信息來進行預處理. 現在新的JDK標準(JDK1.5以上)也支持類似的注解功能,但相比之下很多工具對此提供了更強大更好用的支持. 以IntelliJ IDEA和Eclipse為例,這些IDE工具為JDK 5.0注解功能提供了自動完成和語法高亮功能. 注解被直接編譯到字節碼里,并 在運行時(對于Hibernate來講就是啟動的時候)通過反射讀取這些注解, 因此外部XML文件就不再需要了.
EJB3規范最終認可了透明化ORM的成功范例以及市場對于這種技術的興趣. EJB3規范標準化了ORM的基礎API而且在任何ORM持久化機制中使用元數據. Hibernate EntityManager實現了EJB3持久化規范中定義的編程接口和生命周期規則. 在Hibernate Core的基礎上再結合 Hibernate Annotations就實現了一套完整(并且獨立)的EJB3持久化解決方案. 你可以結合三者來使用,也可以拋開EJB3編程接口和生命周期規則而獨立使用注解, 甚至只單獨使用Hibernate Core. 這些都取決于項目的商業和技術上的實際需求. Hibernate允許你直接使用native APIs,如果有需要, 甚至可以直接操作JDBC和SQL.
做一個簡單的例子!
簡歷好環境
hibernate核心包以及使用注解需要的包, hibernate-annotations.jar 、 ejb3-persistence.jar、hibernate-commons-annotation。
【 ( 最小必要包為antlr.jar,cglib.jar,asm.jar, asm-attrs.jar, commons-collections.jar, commons-loggins.jar ,encache.jar, dom4j.jar,log4j.jar,jta.jar ) 】
附帶hibernate的一些jar包表:
包 | 作用 | 說明 |
jta.jar | JTA(Java任務API)規范,當Hibernate使用JTA的時候需要,不過App Server都會帶上,所以也是多余的。 | 必要 |
commons-logging.jar | Apache Commons包中的一個,包含了日志功能,必須使用的jar包。這個包本身包含了一個Simple Logger,但是功能很弱。在運行的時候它會先在CLASSPATH找log4j,如果有,就使用log4j,如果沒有,就找JDK1.4帶的 java.util.logging,如果也找不到就用Simple Logger。commons-logging.jar的出現是一個歷史的的遺留的遺憾,當初Apache極力游說Sun把log4j加入JDK1.4, 然而JDK1.4項目小組已經接近發布JDK1.4產品的時間了,因此拒絕了Apache的要求,使用自己的java.util.logging,這個包 的功能比log4j差的很遠,性能也一般。 | 必要 |
commons-collections.jar | Apache Commons包中的一個,包含了一些Apache開發的集合類,功能比java.util.*強大。 | 必要 |
antlr.jar | 開源語法分析器(ANTLR—Another Tool for Language Recognition)其前身是PCCTS,它為包括Java,C++,C#在內的語言提供了一個通過語法描述來自動構造自定義語言的識別器(recognizer),編譯器(parser)和解釋器(translator)的框架。ANTLR可以通過斷言(Predicate)解決識別沖突;支持動作(Action)和返回值(Return Value) | 必要 |
dom4j.jar | dom4j是一個Java的XML API,類似于jdom,用來讀寫XML文件的。dom4j是一個非常非常優秀的Java XML API,具有性能優異、功能強大和極端易用使用的特點,同時它也是一個開放源代碼的軟件,可以在SourceForge上找到它。在IBM developerWorks上面可以找到一篇文章,對主流的Java XML API進行的性能、功能和易用性的評測,dom4j無論在那個方面都是非常出色的。我早在將近兩年之前就開始使用dom4j,直到現在。如今你可以看到越 來越多的Java軟件都在使用dom4j來讀寫XML,特別值得一提的是連Sun的JAXM也在用dom4j。這是必須使用的jar 包,Hibernate用它來讀寫配置文件。 | 必要 |
Hibernate3.jar | 核心庫 | 必要 |
asm.jar | ASM(匯編)字節碼庫 | 如果使用“cglib”則必要 |
asm-attrs.jar | ASM字節碼庫 | 如果使用“cglib”則必要 |
ehcache.jar | EHCache緩存 | 如果沒有其它的緩存,則它是必要的 |
cglib.jar | CGLIB庫,Hibernate用它來實現PO(persisent object 持久對象,持久對象實際上必須對應數據庫中的entity,所以和POJO有所區別。比如說POJO是由new創建,由GC回收。但是持久對象是insert數據庫創建,由數據庫delete刪除的。基本上持久對象生命周期和數據庫密切相關。另外持久對象往往只能存在一個數據庫Connection之中,Connnection關閉以后,持久對象就不存在了,而POJO只要不被GC回收,總是存在的。)字節碼的動態生成,非常核心的庫 | 如果使用“cglib”則必要 |
以下包可選 | ||
versioncheck.jar | 版本檢查 | |
swarmcache.jar | ||
jboss-cache.jar | TreeCache | |
jgroups.jar | ||
xml-apis.jar | JAXP API | |
c3p0-0.9.1.jar | C3PO是一個數據庫連接池,Hibernate可以配置為使用C3PO連接池。如果你準備用這個連接池,就需要這個jar包。 | |
connector.jar | JCA API | |
jboss-system.jar | 使用TreeCache時必要 | |
jacc-1_0-fr.jar | JACC 庫 | |
checkstyle-all.jar | ||
junit.jar | ||
javassist.jar | Javassist 字節碼解釋器 | |
ant-lanuncher.jar | ||
jaas.jar | JAAS API | |
jdbc2_0-stdext.jar | JDBC擴展API | |
ant-antlr.jar | Ant antlr支持 | |
jboss-jmx.jar | ||
cleanimports.jar | cleanimports | |
xerces.jar | SAX parser | JDK版本低于1.4時必要 |
jaxen-1.1-beta-7.jar | Jaxen | 如果想提高啟動性能則去使用 |
ant-junit.jar | Ant junit support | |
ant-swing.jar | ant swing support | |
ant.jar | Ant編譯工具的jar包,用來編譯Hibernate源代碼的。如果你不準備修改和編譯Hibernate源代碼,那么就沒有什么用,可選的jar包 | |
proxool.jar | Proxool JDBC連接池 | |
concurrent.jar | 使用TreeCache需要 | |
syndiag2.jar |
mysql數據庫,hiber001數據庫,表:product,使用注解保存一條數據
create database hiber001; create table(id int primary key, name varchar(20), qq varchar(20));
@Entity 表示一個實體類 ,如果不用@table指明,則默認與數據庫中的表名相同(不區分大小寫)。這里我們的類名以及屬性和數據庫的表名以及字段相同!
如果使用注解,則需要在hibernate.cfg.xml中定義經過注解的類:
<mapping class="包名+類名" />
在測試的時候需要用專門的注解管理類,AnnotationConfiguration。
-------------------------------------------------------------------------------------------------------------------------------------
hibernate.cfg.xml
<?xml version='1.0' encoding='UTF-8'?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <!-- Generated by MyEclipse Hibernate Tools. --> <hibernate-configuration> <session-factory> <property name="dialect"> org.hibernate.dialect.MySQLDialect </property> <property name="connection.url"> jdbc:mysql://localhost:3306/hiber001 </property> <property name="connection.username">root</property> <property name="connection.password">123456</property> <property name="connection.driver_class"> com.mysql.jdbc.Driver </property> <property name="myeclipse.connection.profile">mysql5</property> <property name="show_sql">true</property> <!-- annotation part --> <mapping class="com.bubble.entity.Product" /> </session-factory> </hibernate-configuration>
-----------------------------------------------------------------------------------------------------------
hibernate管理類
package com.bubble.util; import org.hibernate.HibernateException; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.cfg.AnnotationConfiguration; /** * @author bubble * */ public class HibernateUtil { // single private static final SessionFactory sessionFactory; static{ try{ //class AnnotationConfiguration:讀取關于Annotation的配置 sessionFactory=new AnnotationConfiguration().configure().buildSessionFactory(); }catch (Throwable e) { // TODO: handle exception throw new ExceptionInInitializerError(e); } } // static method to get session public static Session getSession() throws HibernateException{ return sessionFactory.openSession(); } // close session factory public static void closeSessionFactory(){ sessionFactory.close(); } }
PS:還可以通過編程方式來定義注解的類
sessionFactory = new AnnotationConfiguration() .addPackage("com.bubble.entity") //the fully qualified package name .addAnnotatedClass(Product.class) .buildSessionFactory();
-------------------------------------------------------------------------------------------------------------------------
POJO:product
package com.bubble.entity; import javax.persistence.Entity; import javax.persistence.Id; /** * @author bubble * */ @Entity public class Product { private int id; private String name; private String qq; public void setName(String name) { this.name = name; } public String getName() { return name; } public void setQq(String qq) { this.qq = qq; } public String getQq() { return qq; } public void setId(int id) { this.id = id; } @Id public int getId() { return id; } }
----------------------------------------------------------------------------
測試類:
package com.bubble.test; import org.hibernate.Session; import com.bubble.entity.Product; import com.bubble.util.HibernateUtil; public class AnnoTest { /** * @author bubble 11 / 12 / 05 */ public static void main(String[] args) { // TODO Auto-generated method stub Product p= new Product(); p.setId(1); p.setName("筆記本"); p.setQq("20111205"); Session session=HibernateUtil.getSession();// get session session.beginTransaction(); session.save(p); session.beginTransaction().commit(); session.close(); HibernateUtil.closeSessionFactory(); } }
---------------------------------------------------------------------------------------------------------
Console Result:
2011-12-5 22:41:07 org.hibernate.cfg.annotations.Version <clinit>
信息: Hibernate Annotations 3.3.0.GA
2011-12-5 22:41:07 org.hibernate.cfg.Environment <clinit>
信息: Hibernate 3.2.5
2011-12-5 22:41:07 org.hibernate.cfg.Environment <clinit>
信息: hibernate.properties not found
2011-12-5 22:41:07 org.hibernate.cfg.Environment buildBytecodeProvider
信息: Bytecode provider name : cglib
2011-12-5 22:41:08 org.hibernate.cfg.Environment <clinit>
信息: using JDK 1.4 java.sql.Timestamp handling
2011-12-5 22:41:08 org.hibernate.cfg.Configuration configure
信息: configuring from resource: /hibernate.cfg.xml
2011-12-5 22:41:08 org.hibernate.cfg.Configuration getConfigurationInputStream
信息: Configuration resource: /hibernate.cfg.xml
2011-12-5 22:41:08 org.hibernate.cfg.Configuration doConfigure
信息: Configured SessionFactory: null
2011-12-5 22:41:08 org.hibernate.cfg.AnnotationBinder bindClass
信息: Binding entity from annotated class: com.bubble.entity.Product
2011-12-5 22:41:08 org.hibernate.cfg.annotations.EntityBinder bindTable
信息: Bind entity com.bubble.entity.Product on table Product
2011-12-5 22:41:09 org.hibernate.validator.Version <clinit>
信息: Hibernate Validator 3.0.0.GA
2011-12-5 22:41:09 org.hibernate.connection.DriverManagerConnectionProvider configure
信息: Using Hibernate built-in connection pool (not for production use!)
2011-12-5 22:41:09 org.hibernate.connection.DriverManagerConnectionProvider configure
信息: Hibernate connection pool size: 20
2011-12-5 22:41:09 org.hibernate.connection.DriverManagerConnectionProvider configure
信息: autocommit mode: false
2011-12-5 22:41:09 org.hibernate.connection.DriverManagerConnectionProvider configure
信息: using driver: com.mysql.jdbc.Driver at URL: jdbc:mysql://localhost:3306/hiber001
2011-12-5 22:41:09 org.hibernate.connection.DriverManagerConnectionProvider configure
信息: connection properties: {user=root, password=****}
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: RDBMS: MySQL, version: 5.1.45-community-log
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: JDBC driver: MySQL-AB JDBC Driver, version: mysql-connector-java-5.1.13 ( Revision: ${bzr.revision-id} )
2011-12-5 22:41:10 org.hibernate.dialect.Dialect <init>
信息: Using dialect: org.hibernate.dialect.MySQLDialect
2011-12-5 22:41:10 org.hibernate.transaction.TransactionFactoryFactory buildTransactionFactory
信息: Using default transaction strategy (direct JDBC transactions)
2011-12-5 22:41:10 org.hibernate.transaction.TransactionManagerLookupFactory getTransactionManagerLookup
信息: No TransactionManagerLookup configured (in JTA environment, use of read-write or transactional second-level cache is not recommended)
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Automatic flush during beforeCompletion(): disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Automatic session close at end of transaction: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: JDBC batch size: 15
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: JDBC batch updates for versioned data: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Scrollable result sets: enabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: JDBC3 getGeneratedKeys(): enabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Connection release mode: auto
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Maximum outer join fetch depth: 2
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Default batch fetch size: 1
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Generate SQL with comments: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Order SQL updates by primary key: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Order SQL inserts for batching: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory createQueryTranslatorFactory
信息: Query translator: org.hibernate.hql.ast.ASTQueryTranslatorFactory
2011-12-5 22:41:10 org.hibernate.hql.ast.ASTQueryTranslatorFactory <init>
信息: Using ASTQueryTranslatorFactory
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Query language substitutions: {}
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: JPA-QL strict compliance: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Second-level cache: enabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Query cache: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory createCacheProvider
信息: Cache provider: org.hibernate.cache.NoCacheProvider
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Optimize cache for minimal puts: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Structured second-level cache entries: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Echoing all SQL to stdout
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Statistics: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Deleted entity synthetic identifier rollback: disabled
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Default entity-mode: pojo
2011-12-5 22:41:10 org.hibernate.cfg.SettingsFactory buildSettings
信息: Named query checking : enabled
2011-12-5 22:41:10 org.hibernate.impl.SessionFactoryImpl <init>
信息: building session factory
2011-12-5 22:41:10 org.hibernate.impl.SessionFactoryObjectFactory addInstance
信息: Not binding factory to JNDI, no JNDI name configured
Hibernate: insert into Product (name, qq, id) values (?, ?, ?)
2011-12-5 22:41:11 org.hibernate.impl.SessionFactoryImpl close
信息: closing
2011-12-5 22:41:11 org.hibernate.connection.DriverManagerConnectionProvider close
信息: cleaning up connection pool: jdbc:mysql://localhost:3306/hiber001
查詢數據庫中表數據:
mysql> select * from product; +----+------+----------+ | id | name | qq | +----+------+----------+ | 1 | 筆記本 | 20111205 | +----+------+----------+ 1 row in set (0.00 sec) mysql> delete from product; Query OK, 1 row affected (0.00 sec) mysql>
成功插入一條數據!
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
