Hibernate Tools
Reverse Engineering and Code Generation with Eclipse Plugins and A HBM.XML Editor
Version: 3.0 Alpha 1, 25. January 2005
Please note that this release is a preview release and considered alpha quality. The presented functionality (reverse engineering, code generation, etc.) will soon also be available outside of Eclipse, ie. As Ant tasks. See the Hibernate Tools website for more information About The Road Map.
INTRODUCTION
We have made significant improvements to the Hibernate toolset for Hibernate3. This is however work in progress and we'll continue to implement new ideas and features as the third generation of the Hibernate3 object persistence stack evolves.
The First Set of Tools We Offer Are Plugins for the Eclipse IDE. The Following Features Are Available:
Mapping Editor:. An editor for Hibernate XML mapping files, supporting auto-completion and syntax highlighting It also supports semantic auto-completion for class names and property / field names, making it much more versatile than a normal XML editor.
Console: The console is a new view in Eclipse In addition to a tree overview of your console configurations, you also get an interactive view of your persistent classes and their relationships The console allows you to execute HQL queries against your database and browse the.. Result Directly in Eclipse.
Development Wizards: Several wizards are provided with the Hibernate Eclipse tools; you can use a wizard to quickly generate Hibernate configuration (cfg.xml) files, or you may even completely reverse engineer an existing database schema into POJO source files and Hibernate mapping files. The Reverse Engineering Wizard Supports Customizable Templates.
2. Requirements
Install Eclipse 3.1M4 (http://www.eclipse.org) Install JBoss Eclipse IDE 1.4.x - required for the mapping file editor (http://www.jboss.org/)After you have downloaded the Hibernate Tools for Eclipse Unpack and copy the plugins to your eclipse plugins Directory. You will Also Need JDBC Drivers for Your Database Available To Use The Reverse Engineering and Querying Support.
Please note fully utilize Hibernate that these tools do not try to hide any functionality of Hibernate. The tools make working with Hibernate easier, but you are still encouraged / required to read the documentation for Hibernate to.
3. Creating a hibernate Configuration File
To be able to reverse engineer, prototype queries, and of course to simply use Hibernate a hibernate.properties or hibernate.cfg.xml file is needed. The Hibernate Tools provide a wizard for generating the hibernate.cfg.xml file.
Start the wizard by clicking "New Wizard" (Ctrl N), select the Hibernate / Hibernate Configuration file (cfg.xml) wizard and press "Next". After selecting the location for the hibernate.cfg.xml file, you will see The Following Page:
Creating hibernate.cfg.xml
Enter your configuration information in this dialog. Details about the configuration options can be found in Hibernate reference documentation. Press "Finish" to create the configuration file, it will be automatically opened in an editor.
.
4. XML Mapping Editor
The XML mapping editor provides basic XML editing functionality as well as package, class, and field completion for relevant XML attributes. The auto-completion detects it's context and limits the completion for eg
5. Hibernate Console Perspective
The Hibernate Console perspective combines a set of views which allow you to see the structure of your mapped entities / classes, edit HQL queries, execute the queries, and see the results. To use this perspective you need to create a console configuration.
5.1 Creating a Console Configuration
You create a console configuration by Running The Console Configuration Wizard, Shown In The Following Screenshot:
Creating a hibernate Console Configuration
.
ParameterDescriptionAutodetectNameThe unique name of the configurationName of the Java projectProperty filePath to a hibernate.properties file / td> First hibernate.properties file found in the projectConfiguration filePath to a hibernate.cfg.xmlFirst hibernate.cfg.xml found in the projectMapping filesList of additional mapping files that should be loaded Note:. A hibernate.cfg.xml can also contain mappings, avoid duplication.All hbm.xml files found in the projectClasspathThe classpath for loading POJO and JDBC drivers Do not add Hibernate core libraries or dependencies, they. Are ALREADY INCLUDED.THE DEFAULT Build Output Directory and Any Jars with a class IMPLEMENTING JAVA.SQL.DRIVER
Clicking "Finish" Creates The Configuration and shows it in console overview.5.2 Viewing the Entity Structure
TO View Your New Configuration and Entity / CLICK The Configuration In The List and SELECT "CREATE sessionFactory". This will create a standard Hibernate sessionFactory useing your settings.
Clicking on The Small Symbol Allows You to Browse The Class / Entity Structure and See The Relationships.
Errors durning creation of the sessionfactory (E.G. IF Your configuration is incorrect) Will Be Shown in A Message Dialog, You May Get More Information About The Error In The Error Log View on The Right Pane.
Hibernate Console Perspective Showing Entity Structure, Query Editor and Result
5.3 prototyping queries
Queries CAN Be Executed in Two Ways: by Double Clicking on Entity Names in The Tree Or by Entering HQL in The HQL Editor and Pressing The Green Execute Button.
Results of a Query Will Be Shown In The Query Result View and Details of Possible Errors (Syntax Errors, Database Erroors, etc.) Can Be Seen In The Error Log View.
Tip: HQL queries are executed using list () and without any limit of the size of the output Be careful if you execute a query on a large result set You might run out of memory This will be improved in a future version....
6. Reverse Engineering and Code Generation
A very simple "click-and-generate" reverse engineering and code generation facility is also available. The reverse engineering internally creates a Hibernate meta model. On this meta-model a set of (velocity) templates are applied, generating a set of artifacts . Currently Supported Are Pojo Java Source File, Hibernate * .hbm.xml, and Hibernate.cfg.xml Generation. To Start this Process, Choose The "Hibernate Artifact Generation Wizard". Atact Generation Wizard
First SELECT Which Console Configuration SHOULD BE Used and maping File Generation. Note: Generation Will Generate Files, And Overwrite Possibly existing files in this location.
Now Choose from The Following List of Options:
6.1 REVERSE ENGINEERING
Reverse engineering will connect to your database and read the JDBC metadata of your database schema. The basic rules for the conversion is that each table / view found is mapped to a POJO class, and each column is mapped to a property. The package name controls The "root" package of the generated class.
For Each Found Foreign Key, a
The flag "Generate 'raw' composite ids" turns on special handling of composite primary keys. A
.............. ..
This "EJB3 / JSR-220 annotations" option will activate usage of the EJB3 sections in the javaclass.vm template. This is considered experimental and currently incomplete. Updates to the template are expected, you can even write (and hopefully contribute) more powerful Templates.
The Java code generation is based on aa complete rewrite of the hbm2java found in the Hibernate 2.x toolset. This means that feature-wise they should be equal, but there might be some exotic features not fully implemented so far. Please Report Any Bugs or Missing Code Generation Features Via Our Issue Tracking System.
CONSULT The Hibernate Documentation for the Various Code Generation Tags You CAN Use in your maping file.
6.3 Hibernate Mapping File Generation
This creates a hbm.xml for each class declared in the configuration (and their persistent subclasses). Each
6.4 Hibernate Configuration File Generation
This Option Writes a hibernate.cfg.xml with all Relevant Properties and with a
6.5 Custom Templates
All of the generated code is controlled via templates (Except the hibernate.cfg.xml). The wizard search on the templates in the classpath of the plugin, by default.
You can customize templates by placing your own .vm files in a directory and naming the directory in the wizard dialog. You can override existing templates by using the same file names. The built-in templates can be found in the hibernate-tools.jar In the Org.Hibernate.eclipse Plugin Directory.
You May USE A Pre-Defined Set of Variables and Properties in Templates, as shown in the folowing table.
NameContentsAvailability $ cfgThe current Hibernate Configuration object. See Hibernate3 javadocs for available properties / methods.Anywhere $ c2hA Cfg2HbmTool. Contains a set of helper methods related to cfg to hbm conversion. See sourcecode and existing templates for available properties / methods.Anywhere $ c2jA Cfg2JavaTool . Contains a set of helper methods related to cfg to java conversion. See sourcecode and existing templates for available properties / methods.Anywhere $ clazzA reference to the current PersistentClass or Component being processed.In any class related template $ propertyA reference to the current Property being processedIn any property related templateNote that some of these properties are only available in a certain context (eg $ property is not available at the Class level, but only fo rproperties). If you need to look up some information, you have full access to Hibernate's OWN Meta-Model, The Configuration Via $ CFG. This Combined with the power of velocity templates Should Give You Virtually Unlimited Flexibility and Possibilities for Code Generation.
Note That We Expect Significant Changes To The Structure and Organization of The BUILT-IN TEMPLATES INE OF THE NEXT RELESES.