1 / 16

Mastering Hibernate: Object-Relational Mapping Guide

Learn all about Hibernate, an O/R mapping tool that persists Java classes, eliminates refactoring costs, and offers flexibility in design. Hibernate works with various databases, provides easy testing, and simplifies complex queries. Get started with Hibernate by setting up the environment, mapping objects and relations, and executing queries efficiently.

pettitj
Download Presentation

Mastering Hibernate: Object-Relational Mapping Guide

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Hibernate

  2. Overview • Object/relational persistence and query service • Persists regular Java classes • Interacts with classes using Java reflection • Built atop JDBC

  3. Advantages • Does not force a design on persisted classes • No interface to implement • Testing independent of Hibernate is easy • Refactoring costs much less

  4. O/R Mapping HibernateMapping Objects Relations

  5. Initial Setup • Download Hibernate and Hibernate Extensionswww.hibernate.org • Obtain the JDBC driver for your database • Place all these JARs on your project’s class path • Apache Antant.apache.org

  6. Initial Setup • Create the hibernate.properties file hibernate.dialect=net.sf.hibernate.dialect.MySQLDialect hibernate.connection.driver_class=com.mysql.jdbc.Driver hibernate.connection.url=jdbc:mysql:///cs491b hibernate.connection.username=mnelson hibernate.connection.password=1234

  7. DB2 DB2 AS/400 DB2 OS390 PostgreSQL MySQL Oracle Oracle 9/10g Sybase Sybase Anywhere Microsoft SQL Server SAP DB Informix Hypersonic SQL Ingres Progress Mckoi SQL Interbase Pointbase FrontBase Firebird Dialects

  8. Beginning In The Middle <?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 2.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"><hibernate-mapping> <!-- ... --></hibernate-mapping>

  9. Beginning In The Middle <class name="cs491b.Presentation" table="presentation"> <id name="id" type="int" column="presentation_id"> <generator class="native"/> </id> <property name="subject" type="string" not-null="true"/> <property name="date" type="date" not-null="true"/> <many-to-one name="student“ class="cs491b.Student"></class>

  10. Beginning In The Middle • Use Schema Export tool to derive relations • Use Code Generator tool to derive JavaBeans • Both tools may be invoked: • On the command-line • Via an Ant Task • From within your code

  11. SessionFactory package cs491b;import net.sf.hibernate.*;import net.sf.hibernate.cfg.Configuration;// ...Configuration config = new Configuration();config.addClass(Presentation.class);config.addClass(Student.class);SessionFactory sessionFactory = config.buildSessionFactory();// ...sessionFactory.close();

  12. Session Session session = sessionFactory.openSession();try { // ...} finally { session.close(); }

  13. Session Methods // Find an object with a particular IDsession.load(Presentation.class, 15); // Find objects with a more complex querysession.find("from cs491b.Presentation as pres " + "where pres.date >= ?", myDate, Hibernate.DATE); // Store new objectssession.save(myPresentation);// Delete objects from databasesession.delete(myPresentation); // Save changes to objects created or saved by sessionsession.flush();// Save changes to other objectssession.update(myPresentation);

  14. The Query Builder Query query = session.createQuery( "from cs491b.Presentation as pres " + "where pres.date >= :date");// Or move the SQL code to your Hibernate mapping file query = session.getNamedQuery( "cs491b.presentationsOnOrAfter");query.setDate("date", myDate); query.list();

  15. The Query Builder <query name="cs491b.presentationsOnOrAfter"> <![CDATA[ from cs491b.Presentation as pres where pres.date >= :date ]]></query>

  16. There’s More • Collections and Associations • Lazy loading • Ordered collections • Transactions and Concurrency • HQL • Criteria Queries • Native SQL Queries • See the Hibernate documentation

More Related