Monday, June 27, 2005

 

Searching and indexing with Hibernate

The simple way to search with a small data set is to use the "where" clause in HQL or to use Query or Criteria objects.

However, as the dataset becomes larger and larger we want the text fields searchable by indexing them.

One way of making your hibernate data searchable is using Apache's Lucene framework.

http://lucene.apache.org/java/docs/index.html

Wednesday, June 08, 2005

 

XDoclets for Hibernate

Coding in hibernate involves writing Java bean-like code and them creating a schema to persist that object. The tedious part here is to keep the schema in sync with the bean definition.

There are two common approaches to solve this problem.

In the first approach, one writes the bean definition in hibernate xml and then uses to tool to auto generate the Java bean code.

The second approach is to write a java bean and then generate the hibernate xml from the bean itself.

I personally like the second approach because of several reasons.

1) You write the code in java, and not a proprietry xml. You can provide custom tweaks to the Java code that is not possible when you code in xml.

2) You can convert your Java code to multiple formats if needed. E.g. you could generate a hibernate xml and also any other proprietary conversion that you may want to.

XDoclets for Hibernate is an intuitive way to implement the second approach. All you need to do is put some special tags in you class and method javadoc comments (similar to @param and @returns). The conversion tool reads these comments and generates the hibernate xml.

Here's a sample code that illustrates this:

/** A class representing a car
*
* @hibernate.class table="cars"
**/
public class Car {
int id;

/** The getter method for this Customer's identifier.
*
* @hibernate.id generator-class="assigned"
**/
public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

/**
* Gets the value of color
*
* @hibernate.property
* @return the value of color
*/
public String getColor() {
return this.color;
}

/**
* Sets the value of color
*
* @param argColor Value to assign to this.color
*/
public void setColor(String argColor) {
this.color = argColor;
}
}


The above can be used to generate a hibernate xml definition using the ant task 'generate.hibernate'. The generated xml can then be converted to a database schema using the ant task 'schemaexport'. The schema generated for the above class looks like this:

drop table cars;
create table cars (
id int4 not null,
color varchar(255),
);

Friday, June 03, 2005

 

Switching from JDBC to Hibernate

I started working with Hibernate 6 months ago. Soon I realized that with Hibernate I save 70% of the development time (mostly database code) and now I can't imagine going back to direct database access anytime soon.

This page is powered by Blogger. Isn't yours?