<?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%2FMap_Map</id>
		<title>Java/Hibernate/Map Map - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FHibernate%2FMap_Map"/>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Hibernate/Map_Map&amp;action=history"/>
		<updated>2026-04-22T22:41:18Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Hibernate/Map_Map&amp;diff=7897&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Hibernate/Map_Map&amp;diff=7897&amp;oldid=prev"/>
				<updated>2010-06-01T06:51:32Z</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/Map_Map&amp;diff=7896&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/Map_Map&amp;diff=7896&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;== Collection Mapping: Map Key and Value are Both Objects ==&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.util.*;&lt;br /&gt;
public class Console {&lt;br /&gt;
  private int id;&lt;br /&gt;
  private String name;&lt;br /&gt;
  private Map games;&lt;br /&gt;
  public Console() {&lt;br /&gt;
  }&lt;br /&gt;
  public Console(String name) {&lt;br /&gt;
    this.name = name;&lt;br /&gt;
  }&lt;br /&gt;
  public void setId(int i) {&lt;br /&gt;
    id = i;&lt;br /&gt;
  }&lt;br /&gt;
  public int getId() {&lt;br /&gt;
    return id;&lt;br /&gt;
  }&lt;br /&gt;
  public void setName(String n) {&lt;br /&gt;
    name = n;&lt;br /&gt;
  }&lt;br /&gt;
  public String getName() {&lt;br /&gt;
    return name;&lt;br /&gt;
  }&lt;br /&gt;
  public void setGames(Map m) {&lt;br /&gt;
    games = m;&lt;br /&gt;
  }&lt;br /&gt;
  public Map getGames() {&lt;br /&gt;
    return games;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
public class Game {&lt;br /&gt;
  private int id;&lt;br /&gt;
  private String name;&lt;br /&gt;
  &lt;br /&gt;
  public Game() {&lt;br /&gt;
  }&lt;br /&gt;
  public Game(String name) {&lt;br /&gt;
    this.name = name;&lt;br /&gt;
  }&lt;br /&gt;
  public void setId(int i) {&lt;br /&gt;
    id = i;&lt;br /&gt;
  }&lt;br /&gt;
  public int getId() {&lt;br /&gt;
    return id;&lt;br /&gt;
  }&lt;br /&gt;
  public void setName(String s) {&lt;br /&gt;
    name = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getName() {&lt;br /&gt;
    return name;&lt;br /&gt;
  }&lt;br /&gt;
    public boolean equals(Object obj) {&lt;br /&gt;
        if (obj == null) return false;&lt;br /&gt;
        if (!this.getClass().equals(obj.getClass())) return false;&lt;br /&gt;
        &lt;br /&gt;
        Game obj2 = (Game)obj;&lt;br /&gt;
        if ((this.id == obj2.getId()) &amp;amp;&amp;amp;&lt;br /&gt;
            this.name.equals(obj2.getName())) {&lt;br /&gt;
            return true;&lt;br /&gt;
        }&lt;br /&gt;
        &lt;br /&gt;
    return false;&lt;br /&gt;
    }&lt;br /&gt;
    public int hashCode() {      &lt;br /&gt;
        int tmp = 0;&lt;br /&gt;
        tmp = (id + name).hashCode();&lt;br /&gt;
        return tmp;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.util.*;&lt;br /&gt;
public class GameComparator implements Comparator {&lt;br /&gt;
  public int compare(Object o1, Object o2) { &lt;br /&gt;
        Game game1 = (Game)o1; &lt;br /&gt;
        Game game2 = (Game)o2; &lt;br /&gt;
       return game1.getName().rupareTo(game2.getName()); &lt;br /&gt;
    } &lt;br /&gt;
    public boolean equals(Object obj) {&lt;br /&gt;
        if (obj == null) return false;&lt;br /&gt;
        if (!this.getClass().equals(obj.getClass())) return false;&lt;br /&gt;
        &lt;br /&gt;
               &lt;br /&gt;
    return true;&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;Console.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;
public class Instructions {&lt;br /&gt;
  private int id;&lt;br /&gt;
  private String info;&lt;br /&gt;
  public Instructions() {&lt;br /&gt;
  }&lt;br /&gt;
  public Instructions(String info) {&lt;br /&gt;
    this.info = info;&lt;br /&gt;
  }&lt;br /&gt;
  public void setId(int i) {&lt;br /&gt;
    id = i;&lt;br /&gt;
  }&lt;br /&gt;
  public int getId() {&lt;br /&gt;
    return id;&lt;br /&gt;
  }&lt;br /&gt;
  public void setInfo(String s) {&lt;br /&gt;
    info = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getInfo() {&lt;br /&gt;
    return info;&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 console (id int, name varchar);&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table game (id int, name varchar);&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table instructions (id int, info varchar );&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table game_instructions (parent_id int,game_id int,instructions_id int);&amp;quot;);    &lt;br /&gt;
      Session session = HibernateUtil.currentSession();&lt;br /&gt;
&lt;br /&gt;
      Console sp = new Console(&amp;quot;Console&amp;quot;);&lt;br /&gt;
     &lt;br /&gt;
      TreeMap p = new TreeMap(new GameComparator());&lt;br /&gt;
      Game g = new Game(&amp;quot;Game 1&amp;quot;);&lt;br /&gt;
      Game g2 = new Game(&amp;quot;Game 2&amp;quot;);&lt;br /&gt;
      p.put(g, new Instructions(&amp;quot;Instructions for Game 1&amp;quot;));&lt;br /&gt;
      p.put(g2, new Instructions(&amp;quot;Instructions for Game 2&amp;quot;));&lt;br /&gt;
      sp.setGames(p);&lt;br /&gt;
      session.save(g);&lt;br /&gt;
      session.save(g2);&lt;br /&gt;
      session.flush();&lt;br /&gt;
      session.save(sp);&lt;br /&gt;
      session.flush();&lt;br /&gt;
&lt;br /&gt;
      session.flush();&lt;br /&gt;
      session.close();&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from console&amp;quot;);&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from game&amp;quot;);&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from instructions&amp;quot;);&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from game_instructions&amp;quot;);      &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;Console&amp;quot; table=&amp;quot;console&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&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;map name=&amp;quot;games&amp;quot; table=&amp;quot;game_instructions&amp;quot; sort=&amp;quot;GameComparator&amp;quot; cascade=&amp;quot;all&amp;quot;&amp;gt;&lt;br /&gt;
            &amp;lt;key column=&amp;quot;parent_id&amp;quot;/&amp;gt;&lt;br /&gt;
            &amp;lt;index-many-to-many column=&amp;quot;game_id&amp;quot; class=&amp;quot;Game&amp;quot;/&amp;gt;&lt;br /&gt;
            &amp;lt;many-to-many column=&amp;quot;instructions_id&amp;quot; class=&amp;quot;Instructions&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/map&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;name&amp;quot; type=&amp;quot;string&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/class&amp;gt;&lt;br /&gt;
    &amp;lt;class name=&amp;quot;Game&amp;quot; table=&amp;quot;game&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&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;name&amp;quot; type=&amp;quot;string&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/class&amp;gt;&lt;br /&gt;
    &amp;lt;class name=&amp;quot;Instructions&amp;quot; table=&amp;quot;instructions&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&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;info&amp;quot; type=&amp;quot;string&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;
       &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;
== Collection Mapping: TreeMap ==&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;Console&amp;quot; table=&amp;quot;console&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&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;map name=&amp;quot;games&amp;quot; table=&amp;quot;game_instructions&amp;quot; sort=&amp;quot;GameComparator&amp;quot; cascade=&amp;quot;all&amp;quot;&amp;gt;&lt;br /&gt;
            &amp;lt;key column=&amp;quot;parent_id&amp;quot;/&amp;gt;&lt;br /&gt;
            &amp;lt;index-many-to-many column=&amp;quot;game_id&amp;quot; class=&amp;quot;Game&amp;quot;/&amp;gt;&lt;br /&gt;
            &amp;lt;many-to-many column=&amp;quot;instructions_id&amp;quot; class=&amp;quot;Instructions&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/map&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;name&amp;quot; type=&amp;quot;string&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/class&amp;gt;&lt;br /&gt;
    &amp;lt;class name=&amp;quot;Game&amp;quot; table=&amp;quot;game&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&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;name&amp;quot; type=&amp;quot;string&amp;quot;/&amp;gt;&lt;br /&gt;
    &amp;lt;/class&amp;gt;&lt;br /&gt;
    &amp;lt;class name=&amp;quot;Instructions&amp;quot; table=&amp;quot;instructions&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&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;info&amp;quot; type=&amp;quot;string&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;
import java.util.*;&lt;br /&gt;
public class Console {&lt;br /&gt;
  private int id;&lt;br /&gt;
  private String name;&lt;br /&gt;
  private Map games;&lt;br /&gt;
  public Console() {&lt;br /&gt;
  }&lt;br /&gt;
  public Console(String name) {&lt;br /&gt;
    this.name = name;&lt;br /&gt;
  }&lt;br /&gt;
  public void setId(int i) {&lt;br /&gt;
    id = i;&lt;br /&gt;
  }&lt;br /&gt;
  public int getId() {&lt;br /&gt;
    return id;&lt;br /&gt;
  }&lt;br /&gt;
  public void setName(String n) {&lt;br /&gt;
    name = n;&lt;br /&gt;
  }&lt;br /&gt;
  public String getName() {&lt;br /&gt;
    return name;&lt;br /&gt;
  }&lt;br /&gt;
  public void setGames(Map m) {&lt;br /&gt;
    games = m;&lt;br /&gt;
  }&lt;br /&gt;
  public Map getGames() {&lt;br /&gt;
    return games;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
public class Game {&lt;br /&gt;
  private int id;&lt;br /&gt;
  private String name;&lt;br /&gt;
  &lt;br /&gt;
  public Game() {&lt;br /&gt;
  }&lt;br /&gt;
  public Game(String name) {&lt;br /&gt;
    this.name = name;&lt;br /&gt;
  }&lt;br /&gt;
  public void setId(int i) {&lt;br /&gt;
    id = i;&lt;br /&gt;
  }&lt;br /&gt;
  public int getId() {&lt;br /&gt;
    return id;&lt;br /&gt;
  }&lt;br /&gt;
  public void setName(String s) {&lt;br /&gt;
    name = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getName() {&lt;br /&gt;
    return name;&lt;br /&gt;
  }&lt;br /&gt;
    public boolean equals(Object obj) {&lt;br /&gt;
        if (obj == null) return false;&lt;br /&gt;
        if (!this.getClass().equals(obj.getClass())) return false;&lt;br /&gt;
        &lt;br /&gt;
        Game obj2 = (Game)obj;&lt;br /&gt;
        if ((this.id == obj2.getId()) &amp;amp;&amp;amp;&lt;br /&gt;
            this.name.equals(obj2.getName())) {&lt;br /&gt;
            return true;&lt;br /&gt;
        }&lt;br /&gt;
        &lt;br /&gt;
    return false;&lt;br /&gt;
    }&lt;br /&gt;
    public int hashCode() {      &lt;br /&gt;
        int tmp = 0;&lt;br /&gt;
        tmp = (id + name).hashCode();&lt;br /&gt;
        return tmp;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/////////////////////////////////////////////////////////////////////////&lt;br /&gt;
import java.util.*;&lt;br /&gt;
public class GameComparator implements Comparator {&lt;br /&gt;
  public int compare(Object o1, Object o2) { &lt;br /&gt;
        Game game1 = (Game)o1; &lt;br /&gt;
        Game game2 = (Game)o2; &lt;br /&gt;
       return game1.getName().rupareTo(game2.getName()); &lt;br /&gt;
    } &lt;br /&gt;
    public boolean equals(Object obj) {&lt;br /&gt;
        if (obj == null) return false;&lt;br /&gt;
        if (!this.getClass().equals(obj.getClass())) return false;&lt;br /&gt;
        &lt;br /&gt;
               &lt;br /&gt;
    return true;&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;Console.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;
public class Instructions {&lt;br /&gt;
  private int id;&lt;br /&gt;
  private String info;&lt;br /&gt;
  public Instructions() {&lt;br /&gt;
  }&lt;br /&gt;
  public Instructions(String info) {&lt;br /&gt;
    this.info = info;&lt;br /&gt;
  }&lt;br /&gt;
  public void setId(int i) {&lt;br /&gt;
    id = i;&lt;br /&gt;
  }&lt;br /&gt;
  public int getId() {&lt;br /&gt;
    return id;&lt;br /&gt;
  }&lt;br /&gt;
  public void setInfo(String s) {&lt;br /&gt;
    info = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getInfo() {&lt;br /&gt;
    return info;&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 console (id int, name varchar);&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table game (id int, name varchar);&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table instructions (id int, info varchar );&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table game_instructions (parent_id int,game_id int,instructions_id int);&amp;quot;);    &lt;br /&gt;
      Session session = HibernateUtil.currentSession();&lt;br /&gt;
&lt;br /&gt;
      Console sp = new Console(&amp;quot;Console&amp;quot;);&lt;br /&gt;
     &lt;br /&gt;
      TreeMap p = new TreeMap(new GameComparator());&lt;br /&gt;
      Game g = new Game(&amp;quot;Game 1&amp;quot;);&lt;br /&gt;
      Game g2 = new Game(&amp;quot;Game 2&amp;quot;);&lt;br /&gt;
      p.put(g, new Instructions(&amp;quot;Instructions for Game 1&amp;quot;));&lt;br /&gt;
      p.put(g2, new Instructions(&amp;quot;Instructions for Game 2&amp;quot;));&lt;br /&gt;
      sp.setGames(p);&lt;br /&gt;
      session.save(g);&lt;br /&gt;
      session.save(g2);&lt;br /&gt;
      session.flush();&lt;br /&gt;
      session.save(sp);&lt;br /&gt;
      session.flush();&lt;br /&gt;
&lt;br /&gt;
      session.flush();&lt;br /&gt;
      session.close();&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from console&amp;quot;);&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from game&amp;quot;);&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from instructions&amp;quot;);&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from game_instructions&amp;quot;);      &lt;br /&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;
== Hibernate Collection Mapping Map ==&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-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;SupportProperty.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;
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 supportproperty (id int,name varchar);&amp;quot;);    &lt;br /&gt;
      HibernateUtil.setup(&amp;quot;create table properties (id int,property_name varchar,property_value varchar);&amp;quot;);    &lt;br /&gt;
      Session session = HibernateUtil.currentSession();&lt;br /&gt;
      SupportProperty sp = new SupportProperty();&lt;br /&gt;
     &lt;br /&gt;
      sp.setName(&amp;quot;Joe&amp;quot;);&lt;br /&gt;
      HashMap p = new HashMap();&lt;br /&gt;
      p.put(&amp;quot;color&amp;quot;, &amp;quot;blue&amp;quot;);&lt;br /&gt;
      p.put(&amp;quot;lnf&amp;quot;, &amp;quot;mac&amp;quot;);&lt;br /&gt;
      sp.setProperties(p);&lt;br /&gt;
      session.save(sp);&lt;br /&gt;
      session.flush();&lt;br /&gt;
      HibernateUtil.closeSession();&lt;br /&gt;
      &lt;br /&gt;
      &lt;br /&gt;
      session = HibernateUtil.currentSession();&lt;br /&gt;
      SupportProperty sp2 = (SupportProperty)session.load(SupportProperty.class, new Integer(sp.getId()));&lt;br /&gt;
      Map p2 = sp2.getProperties();&lt;br /&gt;
      System.out.println(p2.get(&amp;quot;color&amp;quot;));&lt;br /&gt;
      System.out.println(p2.get(&amp;quot;lnf&amp;quot;));&lt;br /&gt;
      session.flush();&lt;br /&gt;
      session.close();&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from supportproperty&amp;quot;);&lt;br /&gt;
      HibernateUtil.checkData(&amp;quot;select * from properties&amp;quot;);&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;SupportProperty&amp;quot; table=&amp;quot;supportproperty&amp;quot;&amp;gt;&lt;br /&gt;
        &amp;lt;id name=&amp;quot;id&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;
        &lt;br /&gt;
        &amp;lt;map name=&amp;quot;properties&amp;quot;&amp;gt;&lt;br /&gt;
            &amp;lt;key column=&amp;quot;id&amp;quot;/&amp;gt;&lt;br /&gt;
            &amp;lt;index column=&amp;quot;property_name&amp;quot; type=&amp;quot;string&amp;quot;/&amp;gt;&lt;br /&gt;
            &amp;lt;element column=&amp;quot;property_value&amp;quot; type=&amp;quot;string&amp;quot;/&amp;gt;&lt;br /&gt;
        &amp;lt;/map&amp;gt;&lt;br /&gt;
        &amp;lt;property name=&amp;quot;name&amp;quot; type=&amp;quot;string&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;
import java.util.*;&lt;br /&gt;
public class SupportProperty {&lt;br /&gt;
  private int id;&lt;br /&gt;
  private String name;&lt;br /&gt;
  private Map properties;&lt;br /&gt;
  public SupportProperty() {&lt;br /&gt;
  }&lt;br /&gt;
  public void setId(int i) {&lt;br /&gt;
    id = i;&lt;br /&gt;
  }&lt;br /&gt;
  public int getId() {&lt;br /&gt;
    return id;&lt;br /&gt;
  }&lt;br /&gt;
  public void setName(String s) {&lt;br /&gt;
    name = s;&lt;br /&gt;
  }&lt;br /&gt;
  public String getName() {&lt;br /&gt;
    return name;&lt;br /&gt;
  }&lt;br /&gt;
  public void setProperties(Map m) {&lt;br /&gt;
    properties = m;&lt;br /&gt;
  }&lt;br /&gt;
  public Map getProperties() {&lt;br /&gt;
    return properties;&lt;br /&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;/div&gt;</summary>
			</entry>

	</feed>