Skip to main content

Hibernate 3 with Eclipse helios (Eclipse 3.6)

There are many blogs and tutorials on this topic. However I faced many problems while integrating Hibernate 3.0 with Eclipse Helios. Most of the problems were related to the version mismatch among the components used to create a Hibernate project on Eclipse Helios.
Software Requirements:
1.       Eclipse Helios (This tutorial could work with other versions of Eclipse but it is specially designed for Helios version.)
2.       hibernate-distribution-3.6.5.Final-dist bundle (zip file). Download the bundle from http://www.hibernate.org/downloads. It will be around 59.2 MB jar file.
3.       MySql connector for Eclipse ā€œmysql-connector-java-5.0.8 (zip)ā€.
4.       slf4j-1.6.1 bundle (zip form)
5.       apache-log4j-1.2.16 bundle(zip form)
6.       commons-logging-1.1.1.jar
Pre-Requisites:
1.       In MySql create a database named ā€œdb2ā€.
2.       Under database db2 create a table named ā€œemployeeā€ with following attributes.
CREATE TABLE employee (
                id VARCHAR(10),
                name VARCHAR(20)
);
Note:  The process to connect a MySql table to java code will be described next tutorial.
3.       Add Hibernate perspective to eclipse helios.
Structure of Hibernate Distribution:
        After downloading Hibernate unzip the zip file. Verify following is the file structure you get.


Creating a Hibernate Project in Eclipse Helios:
1. Open Eclipse Helios and select "File | New | Java Project".



2. Name the project as "HibernateTest" (or any other name of your choice). And leave other fields as default.


Now click ā€œNextā€ then ā€œfinishā€.

3.       Project opens in Project Explorer

4.       Now we need to add the necessary jar files to the project. For this Right Click on the Project on the Project Explorer and select ā€œBuild Path | Configure Build Pathā€ from the context menu.


5.       On the build path window select ā€œLibrariesā€ tab. Then click ā€œAdd External Jarsā€ button.


6.  Now add following jars to the projectā€™s build path:
i.  Following jars present under ā€œhibernate-distribution-3.6.5.Final-dist (zip file) ā€œ :
a.       hibernate3.jar
b.      hibernate-testing.jar
ii.  Following files present under ā€œhibernate-distribution-3.6.5.Final-dist (zip file)/lib/requiredā€ :
a.       antlr-2.7.6.jar
b.      commons-collections-3.1.jar
c.       dom4j-1.6.1.jar
d.      javassist-3.12.0.GA.jar
e.      jta-1.1.jar
f.        slf4j-api-1.6.1.jar
iii.   Following jars present under ā€œslf4j-1.6.1 (zip file)ā€ :
a.       jul-to-slf4j-1.6.1.jar
b.      log4j-over-slf4j-1.6.1.jar
c.      slf4j-api-1.6.1.jar
d.      slf4j-ext-1.6.1.jar
e.      slf4j-jcl-1.6.1.jar
f.       slf4j-jdk14-1.6.1.jar
g.      slf4j-log4j12-1.6.1.jar
h.      slf4j-migrator-1.6.1.jar
i.       slf4j-nop-1.6.1.jar
j.       slf4j-simple-1.6.1.jar
iv.   Following jars present under ā€œhibernate-distribution-3.6.5.Final-dist (zip file)/lib/jpaā€ :
a.       hibernate-jpa-2.0-api-1.0.0.Final.jar
v.    Following jars present under ā€œapache-log4j-1.2.16 (zip file)ā€ :
a.       log4j-1.2.16.jar
vi.   Following jars present under ā€œmysql-connector-java-5.0.8 (zip file)ā€ :
a.       mysql-connector-java-5.0.8-bin.jar
vii.  Add ā€œcommons-logging-1.1.1.jarā€ to build path.


7.       After adding all the jars the project structure should look like this:


8.       Now we are done with the addition of jar files. Now the things needed to be done are making classed and xml files. For this first add a package ā€œhibernate.pojoā€ to ā€œsrcā€ folder of project.


9.   Now add a simple Java Bean class ā€œDevTitle.javaā€ to ā€œhibernate.pojoā€ package and add following code to the class.


10.       Now adding a hibernate mapping file that maps this bean class to a backend MySql Table. For this right click on ā€œDevTitle.javaā€ and select ā€œNew | Other | Hibernate | Hibernate XML Mapping File (hbm.xml)ā€


Click ā€œNext >ā€

Click ā€œNext >ā€



Click ā€œNext >ā€


Click ā€œFinishā€

11.       Verify the contents of ā€œDevTitle.hbm.xmlā€ file are as follows:



12.       Now we need to add ā€œhibernate.cfg.xmlā€ file which contains all the configurations related to hibernate


Click ā€œNext >ā€ again click ā€œNext >ā€ then click ā€œFinishā€.
13.       Add following code to ā€œhibernate.cfg.xmlā€

14.       Now we need to add a class that contains a demo code to demonstrate ā€œinsertionā€ and ā€œretrivalā€ of records form out database. For this make a class under ā€œhibernate.pojoā€ named ā€œHibernateTest.javaā€ and paste following code :
package hibernate.pojo;

import java.util.Iterator;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import hibernate.pojo.DevTitle;

public class HibernateTest {

      /**
       * @param args
       */
      public static void main(String[] args) {
           
            Session session=null;
           
            try
            {
                  //Configuration cfg=new Configuration();
                  //cfg.addClass(hibernate.pojo.DevTitle.class);
                  SessionFactory sessionFactory=new Configuration().configure().buildSessionFactory();
                  session=sessionFactory.openSession();
                  //SessionFactory sessionFactory=cfg.configure("hibernate.cfg.xml").buildSessionFactory();
                  System.out.println(sessionFactory);
                  session=sessionFactory.openSession();
                  Transaction txn=session.beginTransaction();
                  System.out.println("inserting record...");
                  DevTitle title=new DevTitle();
                  title.setId("3002");
                  title.setName("rajeev");
                  session.save(title);
                  System.out.println("done....");
                  txn.commit();
                  session.flush();
              session.close();
            }catch(Exception exp){exp.printStackTrace();}
            finally{
                     }
           
            try
            {
                  SessionFactory sessionFactory=new Configuration().configure().buildSessionFactory();
                  session=sessionFactory.openSession();
                  String query1="from DevTitle";
                  Query query=session.createQuery(query1);
                 
                  System.out.println("quering records....");
                  for(Iterator<DevTitle> it=cast(query.iterate()); it.hasNext(); )
                  {
                        DevTitle title=(DevTitle) it.next();
                        System.out.println("ID="+title.getId()+" , name="+title.getName());
                  }
                  session.close();
            }catch(Exception exp){System.out.println(exp.getMessage());}
            finally{}
      }
     
      @SuppressWarnings( "unchecked" )
      private static final <X> X cast(Object o)
      {
            return (X)o;
      }

}

15.              Run the following code as Java Application and if everything is configured properly then following result should get displayed at the console :


Comments

Popular posts from this blog

Using R Programming Language inside Java

Hi, This tutorial walks you through using R programming language inside a java program. R is a powerful programming language for Machine Learning and Data Mining. It contains implementation of various Machine Learning algorithms. Recently i had a situation where i was supposed to use these machine learning algorithms inside my java program. I searched the web but the stuff i found was not of much help. Thus i thought of putting the same in the form of this tutorial. This tutorial is not intended to teach you R language. It is only to help you integrate R to Java and then to use R functions inside a Java program. Pre-requisite: Following things are needed to be pre-configured on your system to use R in Java program: 1. R workbench:  R has got a console known as RGui where R commands/programs could be executed. To install RGui simply go to  http://cran.r-project.org/bin/windows/base/  and download the ' Download R 3.0.2 for Windows   (52 megabytes, 32/64 bit)...

Uploading a binary file to RESTful web service in java using Jersey

Hi, Recently I had a situation where I was supposed to upload a binary file to a server side RESTful web service created in Jersey. I faced a lot of trouble in doing so because always one or the other part of the hood was not working properly. The following post gives a step by step process as how to create a RESTful service that accepts uploaded binary files. Pre-requisites: 1. A running RESTful service based on Jersey. 2. An HTML page with file upload component. 3. Tomcat 7 as web server. 4. Eclipse indigo. Note: Let us suppose that tomcat is running on same machine on which the HTML client is present. So we will be using the base domain URL as ' http://localhost:8080/ '. If your service and client are located on different instances of tomcat then replace the localhost part of the URL with the IP address of the machine on which the REST service is running. Step 1 (Eclipse setup): a. Create a 'Dynamic Web Project' in eclipse indigo. Let us say that thi...

Creating a JAX-WS Web Service and Client using Eclipse Indigo

Creating a JAX-WS Web Service and corresponding client is a very trivial task. However I faced various problems while doing the same mainly while creating a client for the web service. This was mainly because the contents I found on the Internet were in a distributed manner. So I thought of creating a tutorial which binds all the concepts at one place. So this tutorial does not teaches indepth concepts of web services. Instead it guides as how to create a Web Service and a seperate client. Software Requirements: 1. Eclipse Indigo. Note: To download Eclipse Indigo follow the link http://www.eclipse.org/downloads/. Then select 'Eclipse IDE for Java EE Developers'. Process: We will proceed with the creation of web service and client in following two steps: 1. Creating Web Service 2. Creating client to consume web service. 1. Creating Web Service: Creating of a JAX-WS web service is not a very tough task. We simply create a class(normal Java class) and define certai...