<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FHibernate%2FClass_Hiearchy_Mapping</id>
		<title>Java/Hibernate/Class Hiearchy Mapping - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FHibernate%2FClass_Hiearchy_Mapping"/>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Hibernate/Class_Hiearchy_Mapping&amp;action=history"/>
		<updated>2026-04-18T20:26:32Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Hibernate/Class_Hiearchy_Mapping&amp;diff=7917&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Hibernate/Class_Hiearchy_Mapping&amp;diff=7917&amp;oldid=prev"/>
				<updated>2010-06-01T06:51:40Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 06:51, 1 июня 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Hibernate/Class_Hiearchy_Mapping&amp;diff=7916&amp;oldid=prev</id>
		<title> в 18:01, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Hibernate/Class_Hiearchy_Mapping&amp;diff=7916&amp;oldid=prev"/>
				<updated>2010-05-31T18:01:45Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Class Hierachy Mapping Table Per Class ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;utf-8&amp;quot; ?&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE hibernate-mapping &lt;br /&gt;
    PUBLIC &amp;quot;-//Hibernate/Hibernate Mapping DTD//EN&amp;quot; &lt;br /&gt;
    &amp;quot;http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;hibernate-mapping&amp;gt; &lt;br /&gt;
    &amp;lt;class name=&amp;quot;Book&amp;quot; table=&amp;quot;cd&amp;quot; discriminator-value=&amp;quot;cd&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;id name=&amp;quot;id&amp;quot; type=&amp;quot;integer&amp;quot;  unsaved-value=&amp;quot;0&amp;quot;&amp;gt;&lt;br /&gt;
      &amp;lt;generator class=&amp;quot;increment&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/id&amp;gt;&lt;br /&gt;
    &amp;lt;discriminator column=&amp;quot;cd_type&amp;quot; type= &amp;quot;string&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;title&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;artist&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;purchasedate&amp;quot; type=&amp;quot;date&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;cost&amp;quot; type=&amp;quot;double&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;subclass name=&amp;quot;SpecialEditionBook&amp;quot; discriminator-value=&amp;quot;SpecialEditionBook&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;newfeatures&amp;quot; type=&amp;quot;string&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/subclass&amp;gt;&lt;br /&gt;
    &amp;lt;subclass name=&amp;quot;InternationalBook&amp;quot;&lt;br /&gt;
            discriminator-value=&amp;quot;InternationalBook&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;languages&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;region&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/subclass&amp;gt;&lt;br /&gt;
    &amp;lt;/class&amp;gt;&lt;br /&gt;
  &amp;lt;/hibernate-mapping&amp;gt;&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.io.*;&lt;br /&gt;
import java.util.*;&lt;br /&gt;
  public class Book {&lt;br /&gt;
    int id;&lt;br /&gt;
    String title; &lt;br /&gt;
    String artist;&lt;br /&gt;
    Date  purchaseDate; &lt;br /&gt;
    double cost;&lt;br /&gt;
    public Book() {&lt;br /&gt;
    }&lt;br /&gt;
    public Book(String title, String artist, Date purchaseDate, double cost) {&lt;br /&gt;
      this.title = title;&lt;br /&gt;
      this.artist = artist;&lt;br /&gt;
      this.purchaseDate = purchaseDate;&lt;br /&gt;
      this.cost = cost;&lt;br /&gt;
    }&lt;br /&gt;
    public void setId(int id) { &lt;br /&gt;
      this.id = id;&lt;br /&gt;
    }&lt;br /&gt;
    public int getId(){ &lt;br /&gt;
      return id;&lt;br /&gt;
    }&lt;br /&gt;
    public void setTitle(String title) { &lt;br /&gt;
      this.title = title;&lt;br /&gt;
    }&lt;br /&gt;
    public String getTitle() { &lt;br /&gt;
      return title;&lt;br /&gt;
    }&lt;br /&gt;
    public void setArtist(String artist) { &lt;br /&gt;
       this.artist = artist;&lt;br /&gt;
    }&lt;br /&gt;
    public String getArtist() { &lt;br /&gt;
      return artist;&lt;br /&gt;
    }&lt;br /&gt;
    public void setPurchasedate(Date purchaseDate) { &lt;br /&gt;
      this.purchaseDate = purchaseDate;&lt;br /&gt;
    }&lt;br /&gt;
    public Date getPurchasedate() { &lt;br /&gt;
      return purchaseDate;&lt;br /&gt;
    }&lt;br /&gt;
    public void setCost(double cost) { &lt;br /&gt;
      this.cost = cost;&lt;br /&gt;
    }&lt;br /&gt;
    public double getCost() { &lt;br /&gt;
      return cost;&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;utf-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE hibernate-configuration PUBLIC&lt;br /&gt;
    &amp;quot;-//Hibernate/Hibernate Configuration DTD//EN&amp;quot;&lt;br /&gt;
    &amp;quot;http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;hibernate-configuration&amp;gt;&lt;br /&gt;
    &amp;lt;session-factory&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Database connection settings --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.driver_class&amp;quot;&amp;gt;org.hsqldb.jdbcDriver&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.url&amp;quot;&amp;gt;jdbc:hsqldb:data/tutorial&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.username&amp;quot;&amp;gt;sa&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.password&amp;quot;&amp;gt;&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- JDBC connection pool (use the built-in) --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.pool_size&amp;quot;&amp;gt;1&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- SQL dialect --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;dialect&amp;quot;&amp;gt;org.hibernate.dialect.HSQLDialect&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Echo all executed SQL to stdout --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;show_sql&amp;quot;&amp;gt;true&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Mapping files --&amp;gt;&lt;br /&gt;
        &amp;lt;mapping resource=&amp;quot;Book.hbm.xml&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/session-factory&amp;gt;&lt;br /&gt;
&amp;lt;/hibernate-configuration&amp;gt;&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.ResultSetMetaData;&lt;br /&gt;
import org.hibernate.HibernateException;&lt;br /&gt;
import org.hibernate.Session;&lt;br /&gt;
import org.hibernate.SessionFactory;&lt;br /&gt;
import org.hibernate.cfg.Configuration;&lt;br /&gt;
public class HibernateUtil {&lt;br /&gt;
    public static final SessionFactory sessionFactory;&lt;br /&gt;
    static {&lt;br /&gt;
        try {&lt;br /&gt;
            // Create the SessionFactory from hibernate.cfg.xml&lt;br /&gt;
            sessionFactory = new Configuration().configure().buildSessionFactory();&lt;br /&gt;
        } catch (Throwable ex) {&lt;br /&gt;
            // Make sure you log the exception, as it might be swallowed&lt;br /&gt;
            System.err.println(&amp;quot;Initial SessionFactory creation failed.&amp;quot; + ex);&lt;br /&gt;
            throw new ExceptionInInitializerError(ex);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    public static final ThreadLocal session = new ThreadLocal();&lt;br /&gt;
    public static Session currentSession() throws HibernateException {&lt;br /&gt;
        Session s = (Session) session.get();&lt;br /&gt;
        // Open a new Session, if this thread has none yet&lt;br /&gt;
        if (s == null) {&lt;br /&gt;
            s = sessionFactory.openSession();&lt;br /&gt;
            // Store it in the ThreadLocal variable&lt;br /&gt;
            session.set(s);&lt;br /&gt;
        }&lt;br /&gt;
        return s;&lt;br /&gt;
    }&lt;br /&gt;
    public static void closeSession() throws HibernateException {&lt;br /&gt;
        Session s = (Session) session.get();&lt;br /&gt;
        if (s != null)&lt;br /&gt;
            s.close();&lt;br /&gt;
        session.set(null);&lt;br /&gt;
    }&lt;br /&gt;
    &lt;br /&gt;
    static Connection conn; &lt;br /&gt;
    static Statement st;&lt;br /&gt;
  public static void setup(String sql) {&lt;br /&gt;
    try {&lt;br /&gt;
      // Step 1: Load the JDBC driver.&lt;br /&gt;
      Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
      // Step 2: Establish the connection to the database.&lt;br /&gt;
      String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
      conn = DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
      st = conn.createStatement();&lt;br /&gt;
      st.executeUpdate(sql);&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      System.err.println(&amp;quot;Got an exception! &amp;quot;);&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
      System.exit(0);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  public static void checkData(String sql) {&lt;br /&gt;
    try {&lt;br /&gt;
      HibernateUtil.outputResultSet(st&lt;br /&gt;
          .executeQuery(sql));&lt;br /&gt;
//      conn.close();&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
    public static void outputResultSet(ResultSet rs) throws Exception{&lt;br /&gt;
    ResultSetMetaData metadata = rs.getMetaData();&lt;br /&gt;
    int numcols = metadata.getColumnCount();&lt;br /&gt;
    String[] labels = new String[numcols]; &lt;br /&gt;
    int[] colwidths = new int[numcols];&lt;br /&gt;
    int[] colpos = new int[numcols];&lt;br /&gt;
    int linewidth;&lt;br /&gt;
      for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
        labels[i] = metadata.getColumnLabel(i + 1); // get its label&lt;br /&gt;
        System.out.print(labels[i]+&amp;quot;  &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
      System.out.println(&amp;quot;------------------------&amp;quot;);&lt;br /&gt;
    while (rs.next()) {&lt;br /&gt;
        for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
        Object value = rs.getObject(i + 1);&lt;br /&gt;
        if(value == null){&lt;br /&gt;
            System.out.print(&amp;quot;       &amp;quot;);&lt;br /&gt;
        }else{&lt;br /&gt;
            System.out.print(value.toString().trim()+&amp;quot;   &amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
        &lt;br /&gt;
      }&lt;br /&gt;
        System.out.println(&amp;quot;       &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&lt;br /&gt;
import java.util.*;&lt;br /&gt;
public class InternationalBook extends Book { &lt;br /&gt;
  private String languages; &lt;br /&gt;
  private int region;&lt;br /&gt;
  &lt;br /&gt;
  public InternationalBook() {&lt;br /&gt;
  }&lt;br /&gt;
  public InternationalBook(String title, String artist, Date purchaseDate, double cost, String language, int region) {&lt;br /&gt;
    super(title, artist, purchaseDate, cost);&lt;br /&gt;
    languages = language;&lt;br /&gt;
    this.region = region;&lt;br /&gt;
  }&lt;br /&gt;
  public void setLanguages(String s) {&lt;br /&gt;
    languages = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getLanguages() {&lt;br /&gt;
    return languages;&lt;br /&gt;
  }&lt;br /&gt;
  public void setRegion(int i) {&lt;br /&gt;
    region = i;&lt;br /&gt;
  }&lt;br /&gt;
  public int getRegion() {&lt;br /&gt;
    return region;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
log4j.rootCategory=WARN, console&lt;br /&gt;
log4j.appender.console=org.apache.log4j.ConsoleAppender&lt;br /&gt;
log4j.appender.console.layout=org.apache.log4j.PatternLayout&lt;br /&gt;
log4j.appender.console.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n&lt;br /&gt;
log4j.appender.stdout.Target=System.out&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.io.Serializable;&lt;br /&gt;
import java.util.*;&lt;br /&gt;
import org.hibernate.*;&lt;br /&gt;
import org.hibernate.cfg.*;&lt;br /&gt;
import org.hibernate.criterion.*;&lt;br /&gt;
import org.hibernate.event.*;&lt;br /&gt;
import org.hibernate.event.def.*;&lt;br /&gt;
public class Main {&lt;br /&gt;
   public static void main(String[] args) throws Exception {&lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table cd(id int,title varchar,artist varchar,purchasedate date,cost double,newfeatures varchar,languages varchar,region int,cd_type varchar);&amp;quot;);    &lt;br /&gt;
&lt;br /&gt;
      Session session = HibernateUtil.currentSession();&lt;br /&gt;
      Book cd = new Book(&amp;quot;Book&amp;quot;, &amp;quot;R&amp;quot;, new Date(), 9.99);&lt;br /&gt;
      SpecialEditionBook secd = new SpecialEditionBook(&amp;quot;sBook&amp;quot;, &amp;quot;R&amp;quot;, new Date(), 9.99, &amp;quot;W&amp;quot;);&lt;br /&gt;
      InternationalBook icd = new InternationalBook(&amp;quot;IBook&amp;quot;, &amp;quot;R&amp;quot;, new Date(), 9.99, &amp;quot;S&amp;quot;, 4);&lt;br /&gt;
      session.save(cd);&lt;br /&gt;
      session.save(secd);&lt;br /&gt;
      session.save(icd);&lt;br /&gt;
      session.flush();      &lt;br /&gt;
      session.close();&lt;br /&gt;
     HibernateUtil.checkData(&amp;quot;select * from cd&amp;quot;);&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.util.*;&lt;br /&gt;
public class SpecialEditionBook extends Book { &lt;br /&gt;
  private String newfeatures;&lt;br /&gt;
  &lt;br /&gt;
  public SpecialEditionBook() {&lt;br /&gt;
  }&lt;br /&gt;
    public SpecialEditionBook(String title, String artist, Date purchaseDate, double cost, String features) {&lt;br /&gt;
      super(title, artist, purchaseDate, cost);&lt;br /&gt;
      newfeatures = features;&lt;br /&gt;
    }&lt;br /&gt;
  public void setNewfeatures(String s) {&lt;br /&gt;
    newfeatures = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getNewfeatures() {&lt;br /&gt;
    return newfeatures;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Class Hierarchy Mapping Table Per Concrete Class ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.io.*;&lt;br /&gt;
import java.util.*;&lt;br /&gt;
  public class Book {&lt;br /&gt;
    int id;&lt;br /&gt;
    String title; &lt;br /&gt;
    String artist;&lt;br /&gt;
    Date  purchaseDate; &lt;br /&gt;
    double cost;&lt;br /&gt;
    public Book() {&lt;br /&gt;
    }&lt;br /&gt;
    public Book(String title, String artist, Date purchaseDate, double cost) {&lt;br /&gt;
      this.title = title;&lt;br /&gt;
      this.artist = artist;&lt;br /&gt;
      this.purchaseDate = purchaseDate;&lt;br /&gt;
      this.cost = cost;&lt;br /&gt;
    }&lt;br /&gt;
    public void setId(int id) { &lt;br /&gt;
      this.id = id;&lt;br /&gt;
    }&lt;br /&gt;
    public int getId(){ &lt;br /&gt;
      return id;&lt;br /&gt;
    }&lt;br /&gt;
    public void setTitle(String title) { &lt;br /&gt;
      this.title = title;&lt;br /&gt;
    }&lt;br /&gt;
    public String getTitle() { &lt;br /&gt;
      return title;&lt;br /&gt;
    }&lt;br /&gt;
    public void setArtist(String artist) { &lt;br /&gt;
       this.artist = artist;&lt;br /&gt;
    }&lt;br /&gt;
    public String getArtist() { &lt;br /&gt;
      return artist;&lt;br /&gt;
    }&lt;br /&gt;
    public void setPurchasedate(Date purchaseDate) { &lt;br /&gt;
      this.purchaseDate = purchaseDate;&lt;br /&gt;
    }&lt;br /&gt;
    public Date getPurchasedate() { &lt;br /&gt;
      return purchaseDate;&lt;br /&gt;
    }&lt;br /&gt;
    public void setCost(double cost) { &lt;br /&gt;
      this.cost = cost;&lt;br /&gt;
    }&lt;br /&gt;
    public double getCost() { &lt;br /&gt;
      return cost;&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;utf-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE hibernate-configuration PUBLIC&lt;br /&gt;
    &amp;quot;-//Hibernate/Hibernate Configuration DTD//EN&amp;quot;&lt;br /&gt;
    &amp;quot;http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;hibernate-configuration&amp;gt;&lt;br /&gt;
    &amp;lt;session-factory&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Database connection settings --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.driver_class&amp;quot;&amp;gt;org.hsqldb.jdbcDriver&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.url&amp;quot;&amp;gt;jdbc:hsqldb:data/tutorial&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.username&amp;quot;&amp;gt;sa&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.password&amp;quot;&amp;gt;&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- JDBC connection pool (use the built-in) --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.pool_size&amp;quot;&amp;gt;1&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- SQL dialect --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;dialect&amp;quot;&amp;gt;org.hibernate.dialect.HSQLDialect&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Echo all executed SQL to stdout --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;show_sql&amp;quot;&amp;gt;true&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Mapping files --&amp;gt;&lt;br /&gt;
        &amp;lt;mapping resource=&amp;quot;Book.hbm.xml&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/session-factory&amp;gt;&lt;br /&gt;
&amp;lt;/hibernate-configuration&amp;gt;&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.ResultSetMetaData;&lt;br /&gt;
import org.hibernate.HibernateException;&lt;br /&gt;
import org.hibernate.Session;&lt;br /&gt;
import org.hibernate.SessionFactory;&lt;br /&gt;
import org.hibernate.cfg.Configuration;&lt;br /&gt;
public class HibernateUtil {&lt;br /&gt;
    public static final SessionFactory sessionFactory;&lt;br /&gt;
    static {&lt;br /&gt;
        try {&lt;br /&gt;
            // Create the SessionFactory from hibernate.cfg.xml&lt;br /&gt;
            sessionFactory = new Configuration().configure().buildSessionFactory();&lt;br /&gt;
        } catch (Throwable ex) {&lt;br /&gt;
            // Make sure you log the exception, as it might be swallowed&lt;br /&gt;
            System.err.println(&amp;quot;Initial SessionFactory creation failed.&amp;quot; + ex);&lt;br /&gt;
            throw new ExceptionInInitializerError(ex);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    public static final ThreadLocal session = new ThreadLocal();&lt;br /&gt;
    public static Session currentSession() throws HibernateException {&lt;br /&gt;
        Session s = (Session) session.get();&lt;br /&gt;
        // Open a new Session, if this thread has none yet&lt;br /&gt;
        if (s == null) {&lt;br /&gt;
            s = sessionFactory.openSession();&lt;br /&gt;
            // Store it in the ThreadLocal variable&lt;br /&gt;
            session.set(s);&lt;br /&gt;
        }&lt;br /&gt;
        return s;&lt;br /&gt;
    }&lt;br /&gt;
    public static void closeSession() throws HibernateException {&lt;br /&gt;
        Session s = (Session) session.get();&lt;br /&gt;
        if (s != null)&lt;br /&gt;
            s.close();&lt;br /&gt;
        session.set(null);&lt;br /&gt;
    }&lt;br /&gt;
    &lt;br /&gt;
    static Connection conn; &lt;br /&gt;
    static Statement st;&lt;br /&gt;
  public static void setup(String sql) {&lt;br /&gt;
    try {&lt;br /&gt;
      // Step 1: Load the JDBC driver.&lt;br /&gt;
      Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
      // Step 2: Establish the connection to the database.&lt;br /&gt;
      String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
      conn = DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
      st = conn.createStatement();&lt;br /&gt;
      st.executeUpdate(sql);&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      System.err.println(&amp;quot;Got an exception! &amp;quot;);&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
      System.exit(0);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  public static void checkData(String sql) {&lt;br /&gt;
    try {&lt;br /&gt;
      HibernateUtil.outputResultSet(st&lt;br /&gt;
          .executeQuery(sql));&lt;br /&gt;
//      conn.close();&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
    public static void outputResultSet(ResultSet rs) throws Exception{&lt;br /&gt;
    ResultSetMetaData metadata = rs.getMetaData();&lt;br /&gt;
    int numcols = metadata.getColumnCount();&lt;br /&gt;
    String[] labels = new String[numcols]; &lt;br /&gt;
    int[] colwidths = new int[numcols];&lt;br /&gt;
    int[] colpos = new int[numcols];&lt;br /&gt;
    int linewidth;&lt;br /&gt;
      for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
        labels[i] = metadata.getColumnLabel(i + 1); // get its label&lt;br /&gt;
        System.out.print(labels[i]+&amp;quot;  &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
      System.out.println(&amp;quot;------------------------&amp;quot;);&lt;br /&gt;
    while (rs.next()) {&lt;br /&gt;
        for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
        Object value = rs.getObject(i + 1);&lt;br /&gt;
        if(value == null){&lt;br /&gt;
            System.out.print(&amp;quot;       &amp;quot;);&lt;br /&gt;
        }else{&lt;br /&gt;
            System.out.print(value.toString().trim()+&amp;quot;   &amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
        &lt;br /&gt;
      }&lt;br /&gt;
        System.out.println(&amp;quot;       &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.util.*;&lt;br /&gt;
public class InternationalBook extends Book { &lt;br /&gt;
  private String languages; &lt;br /&gt;
  private int region;&lt;br /&gt;
  &lt;br /&gt;
  public InternationalBook() {&lt;br /&gt;
  }&lt;br /&gt;
  public InternationalBook(String title, String artist, Date purchaseDate, double cost, String language, int region) {&lt;br /&gt;
    super(title, artist, purchaseDate, cost);&lt;br /&gt;
    languages = language;&lt;br /&gt;
    this.region = region;&lt;br /&gt;
  }&lt;br /&gt;
  public void setLanguages(String s) {&lt;br /&gt;
    languages = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getLanguages() {&lt;br /&gt;
    return languages;&lt;br /&gt;
  }&lt;br /&gt;
  public void setRegion(int i) {&lt;br /&gt;
    region = i;&lt;br /&gt;
  }&lt;br /&gt;
  public int getRegion() {&lt;br /&gt;
    return region;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&lt;br /&gt;
import java.io.Serializable;&lt;br /&gt;
import java.util.*;&lt;br /&gt;
import org.hibernate.*;&lt;br /&gt;
import org.hibernate.cfg.*;&lt;br /&gt;
import org.hibernate.criterion.*;&lt;br /&gt;
import org.hibernate.event.*;&lt;br /&gt;
import org.hibernate.event.def.*;&lt;br /&gt;
public class Main {&lt;br /&gt;
   public static void main(String[] args) throws Exception {&lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table cd(id int,title varchar,artist varchar,purchasedate date,cost double);&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table secd(id int,title varchar,artist varchar,purchasedate date,cost double,newfeatures varchar);&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table icd(id int,title varchar,artist varchar,purchasedate date,cost double,languages varchar,region int);&amp;quot;);    &lt;br /&gt;
&lt;br /&gt;
      Session session = HibernateUtil.currentSession();&lt;br /&gt;
      Book cd = new Book(&amp;quot;Book&amp;quot;, &amp;quot;R&amp;quot;, new Date(), 9.99);&lt;br /&gt;
      SpecialEditionBook secd = new SpecialEditionBook(&amp;quot;sBook&amp;quot;, &amp;quot;R&amp;quot;, new Date(), 9.99, &amp;quot;W&amp;quot;);&lt;br /&gt;
      InternationalBook icd = new InternationalBook(&amp;quot;IBook&amp;quot;, &amp;quot;R&amp;quot;, new Date(), 9.99, &amp;quot;S&amp;quot;, 4);&lt;br /&gt;
      session.save(cd);&lt;br /&gt;
      session.save(secd);&lt;br /&gt;
      session.save(icd);&lt;br /&gt;
      session.flush();      &lt;br /&gt;
      session.close();&lt;br /&gt;
     HibernateUtil.checkData(&amp;quot;select * from cd&amp;quot;);&lt;br /&gt;
     HibernateUtil.checkData(&amp;quot;select * from secd&amp;quot;);&lt;br /&gt;
     HibernateUtil.checkData(&amp;quot;select * from icd&amp;quot;);&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.util.*;&lt;br /&gt;
public class SpecialEditionBook extends Book { &lt;br /&gt;
  private String newfeatures;&lt;br /&gt;
  &lt;br /&gt;
  public SpecialEditionBook() {&lt;br /&gt;
  }&lt;br /&gt;
    public SpecialEditionBook(String title, String artist, Date purchaseDate, double cost, String features) {&lt;br /&gt;
      super(title, artist, purchaseDate, cost);&lt;br /&gt;
      newfeatures = features;&lt;br /&gt;
    }&lt;br /&gt;
  public void setNewfeatures(String s) {&lt;br /&gt;
    newfeatures = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getNewfeatures() {&lt;br /&gt;
    return newfeatures;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;utf-8&amp;quot; ?&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE hibernate-mapping &lt;br /&gt;
    PUBLIC &amp;quot;-//Hibernate/Hibernate Mapping DTD//EN&amp;quot; &lt;br /&gt;
    &amp;quot;http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;hibernate-mapping&amp;gt; &lt;br /&gt;
    &amp;lt;class name=&amp;quot;Book&amp;quot; table=&amp;quot;cd&amp;quot; discriminator-value=&amp;quot;cd&amp;quot;&amp;gt; &lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&amp;quot; type=&amp;quot;integer&amp;quot; unsaved-value=&amp;quot;0&amp;quot;&amp;gt;&lt;br /&gt;
            &amp;lt;generator  class=&amp;quot;increment&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/id&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;title&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;artist&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;purchasedate&amp;quot; type=&amp;quot;date&amp;quot;/&amp;gt; &lt;br /&gt;
        &amp;lt;property name=&amp;quot;cost&amp;quot; type=&amp;quot;double&amp;quot;/&amp;gt; &lt;br /&gt;
    &amp;lt;/class&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
    &amp;lt;class  name=&amp;quot;SpecialEditionBook&amp;quot; table=&amp;quot;secd&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&amp;quot; type=&amp;quot;integer&amp;quot; unsaved-value=&amp;quot;0&amp;quot;&amp;gt;&lt;br /&gt;
            &amp;lt;generator  class=&amp;quot;increment&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/id&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;title&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;artist&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;purchasedate&amp;quot; type=&amp;quot;date&amp;quot;/&amp;gt; &lt;br /&gt;
        &amp;lt;property name=&amp;quot;cost&amp;quot; type=&amp;quot;double&amp;quot;/&amp;gt; &lt;br /&gt;
        &amp;lt;property name=&amp;quot;newfeatures&amp;quot; type=&amp;quot;string&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/class&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
    &amp;lt;class  name=&amp;quot;InternationalBook&amp;quot; table=&amp;quot;icd&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&amp;quot; type=&amp;quot;integer&amp;quot; unsaved-value=&amp;quot;0&amp;quot;&amp;gt;&lt;br /&gt;
            &amp;lt;generator  class=&amp;quot;increment&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/id&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;title&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;artist&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;purchasedate&amp;quot; type=&amp;quot;date&amp;quot;/&amp;gt; &lt;br /&gt;
        &amp;lt;property name=&amp;quot;cost&amp;quot; type=&amp;quot;double&amp;quot;/&amp;gt; &lt;br /&gt;
        &amp;lt;property name=&amp;quot;languages&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;region&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/class&amp;gt; &lt;br /&gt;
&amp;lt;/hibernate-mapping&amp;gt;&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ClassHierchy Mapping Table Per Sub class ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;utf-8&amp;quot; ?&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE hibernate-mapping &lt;br /&gt;
    PUBLIC &amp;quot;-//Hibernate/Hibernate Mapping DTD//EN&amp;quot; &lt;br /&gt;
    &amp;quot;http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;hibernate-mapping&amp;gt; &lt;br /&gt;
 &amp;lt;class name=&amp;quot;Book&amp;quot;&lt;br /&gt;
         table=&amp;quot;cd&amp;quot;&amp;gt;&lt;br /&gt;
     &amp;lt;id name=&amp;quot;id&amp;quot;&lt;br /&gt;
         type=&amp;quot;integer&amp;quot;&lt;br /&gt;
         unsaved-value=&amp;quot;0&amp;quot;&amp;gt;&lt;br /&gt;
       &amp;lt;generator class=&amp;quot;increment&amp;quot;/&amp;gt;&lt;br /&gt;
     &amp;lt;/id&amp;gt;&lt;br /&gt;
  &amp;lt;property name=&amp;quot;title&amp;quot;/&amp;gt;&lt;br /&gt;
         &amp;lt;property name=&amp;quot;artist&amp;quot;/&amp;gt;&lt;br /&gt;
         &amp;lt;property name=&amp;quot;purchasedate&amp;quot; type=&amp;quot;date&amp;quot;/&amp;gt;&lt;br /&gt;
         &amp;lt;property name=&amp;quot;cost&amp;quot; type=&amp;quot;double&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;joined-subclass name=&amp;quot;SpecialEditionBook&amp;quot;&lt;br /&gt;
                   table=&amp;quot;secd&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;key column=&amp;quot;id&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;newfeatures&amp;quot; type=&amp;quot;string&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/joined-subclass&amp;gt;&lt;br /&gt;
  &amp;lt;joined-subclass name=&amp;quot;InternationalBook&amp;quot;&lt;br /&gt;
                   table=&amp;quot;icd&amp;quot;&amp;gt;&lt;br /&gt;
    &amp;lt;key column=&amp;quot;id&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;languages&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;property name=&amp;quot;region&amp;quot;/&amp;gt;&lt;br /&gt;
  &amp;lt;/joined-subclass&amp;gt;&lt;br /&gt;
  &amp;lt;/class&amp;gt;&lt;br /&gt;
&amp;lt;/hibernate-mapping&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.io.*;&lt;br /&gt;
import java.util.*;&lt;br /&gt;
  public class Book {&lt;br /&gt;
    int id;&lt;br /&gt;
    String title; &lt;br /&gt;
    String artist;&lt;br /&gt;
    Date  purchaseDate; &lt;br /&gt;
    double cost;&lt;br /&gt;
    public Book() {&lt;br /&gt;
    }&lt;br /&gt;
    public Book(String title, String artist, Date purchaseDate, double cost) {&lt;br /&gt;
      this.title = title;&lt;br /&gt;
      this.artist = artist;&lt;br /&gt;
      this.purchaseDate = purchaseDate;&lt;br /&gt;
      this.cost = cost;&lt;br /&gt;
    }&lt;br /&gt;
    public void setId(int id) { &lt;br /&gt;
      this.id = id;&lt;br /&gt;
    }&lt;br /&gt;
    public int getId(){ &lt;br /&gt;
      return id;&lt;br /&gt;
    }&lt;br /&gt;
    public void setTitle(String title) { &lt;br /&gt;
      this.title = title;&lt;br /&gt;
    }&lt;br /&gt;
    public String getTitle() { &lt;br /&gt;
      return title;&lt;br /&gt;
    }&lt;br /&gt;
    public void setArtist(String artist) { &lt;br /&gt;
       this.artist = artist;&lt;br /&gt;
    }&lt;br /&gt;
    public String getArtist() { &lt;br /&gt;
      return artist;&lt;br /&gt;
    }&lt;br /&gt;
    public void setPurchasedate(Date purchaseDate) { &lt;br /&gt;
      this.purchaseDate = purchaseDate;&lt;br /&gt;
    }&lt;br /&gt;
    public Date getPurchasedate() { &lt;br /&gt;
      return purchaseDate;&lt;br /&gt;
    }&lt;br /&gt;
    public void setCost(double cost) { &lt;br /&gt;
      this.cost = cost;&lt;br /&gt;
    }&lt;br /&gt;
    public double getCost() { &lt;br /&gt;
      return cost;&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&amp;lt;?xml version=&amp;quot;1.0&amp;quot; encoding=&amp;quot;utf-8&amp;quot;?&amp;gt;&lt;br /&gt;
&amp;lt;!DOCTYPE hibernate-configuration PUBLIC&lt;br /&gt;
    &amp;quot;-//Hibernate/Hibernate Configuration DTD//EN&amp;quot;&lt;br /&gt;
    &amp;quot;http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;hibernate-configuration&amp;gt;&lt;br /&gt;
    &amp;lt;session-factory&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Database connection settings --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.driver_class&amp;quot;&amp;gt;org.hsqldb.jdbcDriver&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.url&amp;quot;&amp;gt;jdbc:hsqldb:data/tutorial&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.username&amp;quot;&amp;gt;sa&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.password&amp;quot;&amp;gt;&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- JDBC connection pool (use the built-in) --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;connection.pool_size&amp;quot;&amp;gt;1&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- SQL dialect --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;dialect&amp;quot;&amp;gt;org.hibernate.dialect.HSQLDialect&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Echo all executed SQL to stdout --&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;show_sql&amp;quot;&amp;gt;true&amp;lt;/property&amp;gt;&lt;br /&gt;
        &amp;lt;!-- Mapping files --&amp;gt;&lt;br /&gt;
        &amp;lt;mapping resource=&amp;quot;Book.hbm.xml&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/session-factory&amp;gt;&lt;br /&gt;
&amp;lt;/hibernate-configuration&amp;gt;&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.ResultSetMetaData;&lt;br /&gt;
import org.hibernate.HibernateException;&lt;br /&gt;
import org.hibernate.Session;&lt;br /&gt;
import org.hibernate.SessionFactory;&lt;br /&gt;
import org.hibernate.cfg.Configuration;&lt;br /&gt;
public class HibernateUtil {&lt;br /&gt;
    public static final SessionFactory sessionFactory;&lt;br /&gt;
    static {&lt;br /&gt;
        try {&lt;br /&gt;
            // Create the SessionFactory from hibernate.cfg.xml&lt;br /&gt;
            sessionFactory = new Configuration().configure().buildSessionFactory();&lt;br /&gt;
        } catch (Throwable ex) {&lt;br /&gt;
            // Make sure you log the exception, as it might be swallowed&lt;br /&gt;
            System.err.println(&amp;quot;Initial SessionFactory creation failed.&amp;quot; + ex);&lt;br /&gt;
            throw new ExceptionInInitializerError(ex);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
    public static final ThreadLocal session = new ThreadLocal();&lt;br /&gt;
    public static Session currentSession() throws HibernateException {&lt;br /&gt;
        Session s = (Session) session.get();&lt;br /&gt;
        // Open a new Session, if this thread has none yet&lt;br /&gt;
        if (s == null) {&lt;br /&gt;
            s = sessionFactory.openSession();&lt;br /&gt;
            // Store it in the ThreadLocal variable&lt;br /&gt;
            session.set(s);&lt;br /&gt;
        }&lt;br /&gt;
        return s;&lt;br /&gt;
    }&lt;br /&gt;
    public static void closeSession() throws HibernateException {&lt;br /&gt;
        Session s = (Session) session.get();&lt;br /&gt;
        if (s != null)&lt;br /&gt;
            s.close();&lt;br /&gt;
        session.set(null);&lt;br /&gt;
    }&lt;br /&gt;
    &lt;br /&gt;
    static Connection conn; &lt;br /&gt;
    static Statement st;&lt;br /&gt;
  public static void setup(String sql) {&lt;br /&gt;
    try {&lt;br /&gt;
      // Step 1: Load the JDBC driver.&lt;br /&gt;
      Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
      // Step 2: Establish the connection to the database.&lt;br /&gt;
      String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
      conn = DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
      st = conn.createStatement();&lt;br /&gt;
      st.executeUpdate(sql);&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      System.err.println(&amp;quot;Got an exception! &amp;quot;);&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
      System.exit(0);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  public static void checkData(String sql) {&lt;br /&gt;
    try {&lt;br /&gt;
      HibernateUtil.outputResultSet(st&lt;br /&gt;
          .executeQuery(sql));&lt;br /&gt;
//      conn.close();&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
    public static void outputResultSet(ResultSet rs) throws Exception{&lt;br /&gt;
    ResultSetMetaData metadata = rs.getMetaData();&lt;br /&gt;
    int numcols = metadata.getColumnCount();&lt;br /&gt;
    String[] labels = new String[numcols]; &lt;br /&gt;
    int[] colwidths = new int[numcols];&lt;br /&gt;
    int[] colpos = new int[numcols];&lt;br /&gt;
    int linewidth;&lt;br /&gt;
      for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
        labels[i] = metadata.getColumnLabel(i + 1); // get its label&lt;br /&gt;
        System.out.print(labels[i]+&amp;quot;  &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
      System.out.println(&amp;quot;------------------------&amp;quot;);&lt;br /&gt;
    while (rs.next()) {&lt;br /&gt;
        for (int i = 0; i &amp;lt; numcols; i++) {&lt;br /&gt;
        Object value = rs.getObject(i + 1);&lt;br /&gt;
        if(value == null){&lt;br /&gt;
            System.out.print(&amp;quot;       &amp;quot;);&lt;br /&gt;
        }else{&lt;br /&gt;
            System.out.print(value.toString().trim()+&amp;quot;   &amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
        &lt;br /&gt;
      }&lt;br /&gt;
        System.out.println(&amp;quot;       &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
&lt;br /&gt;
import java.util.*;&lt;br /&gt;
public class InternationalBook extends Book { &lt;br /&gt;
  private String languages; &lt;br /&gt;
  private int region;&lt;br /&gt;
  &lt;br /&gt;
  public InternationalBook() {&lt;br /&gt;
  }&lt;br /&gt;
  public InternationalBook(String title, String artist, Date purchaseDate, double cost, String language, int region) {&lt;br /&gt;
    super(title, artist, purchaseDate, cost);&lt;br /&gt;
    languages = language;&lt;br /&gt;
    this.region = region;&lt;br /&gt;
  }&lt;br /&gt;
  public void setLanguages(String s) {&lt;br /&gt;
    languages = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getLanguages() {&lt;br /&gt;
    return languages;&lt;br /&gt;
  }&lt;br /&gt;
  public void setRegion(int i) {&lt;br /&gt;
    region = i;&lt;br /&gt;
  }&lt;br /&gt;
  public int getRegion() {&lt;br /&gt;
    return region;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
log4j.rootCategory=WARN, console&lt;br /&gt;
log4j.appender.console=org.apache.log4j.ConsoleAppender&lt;br /&gt;
log4j.appender.console.layout=org.apache.log4j.PatternLayout&lt;br /&gt;
log4j.appender.console.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n&lt;br /&gt;
log4j.appender.stdout.Target=System.out&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.io.Serializable;&lt;br /&gt;
import java.util.*;&lt;br /&gt;
import org.hibernate.*;&lt;br /&gt;
import org.hibernate.cfg.*;&lt;br /&gt;
import org.hibernate.criterion.*;&lt;br /&gt;
import org.hibernate.event.*;&lt;br /&gt;
import org.hibernate.event.def.*;&lt;br /&gt;
public class Main {&lt;br /&gt;
   public static void main(String[] args) throws Exception {&lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table cd(id int,title varchar,artist varchar,purchasedate date,cost double);&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table secd(id int,newfeatures varchar);&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table icd(id int,languages varchar,region int);&amp;quot;);    &lt;br /&gt;
      Session session = HibernateUtil.currentSession();&lt;br /&gt;
      Book cd = new Book(&amp;quot;Book&amp;quot;, &amp;quot;R&amp;quot;, new Date(), 9.99);&lt;br /&gt;
      SpecialEditionBook secd = new SpecialEditionBook(&amp;quot;sBook&amp;quot;, &amp;quot;R&amp;quot;, new Date(), 9.99, &amp;quot;W&amp;quot;);&lt;br /&gt;
      InternationalBook icd = new InternationalBook(&amp;quot;IBook&amp;quot;, &amp;quot;R&amp;quot;, new Date(), 9.99, &amp;quot;S&amp;quot;, 4);&lt;br /&gt;
      session.save(cd);&lt;br /&gt;
      session.save(secd);&lt;br /&gt;
      session.save(icd);&lt;br /&gt;
      session.flush();      &lt;br /&gt;
      session.close();&lt;br /&gt;
     HibernateUtil.checkData(&amp;quot;select * from cd&amp;quot;);&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.util.*;&lt;br /&gt;
public class SpecialEditionBook extends Book { &lt;br /&gt;
  private String newfeatures;&lt;br /&gt;
  &lt;br /&gt;
  public SpecialEditionBook() {&lt;br /&gt;
  }&lt;br /&gt;
    public SpecialEditionBook(String title, String artist, Date purchaseDate, double cost, String features) {&lt;br /&gt;
      super(title, artist, purchaseDate, cost);&lt;br /&gt;
      newfeatures = features;&lt;br /&gt;
    }&lt;br /&gt;
  public void setNewfeatures(String s) {&lt;br /&gt;
    newfeatures = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getNewfeatures() {&lt;br /&gt;
    return newfeatures;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;/div&gt;</summary>
			</entry>

	</feed>