InstallationDerby
Derby Installation
- Derby in Embedded mode is a very simple database to configure as you don't need to install nor to start it before being able to use it. It comes as a single JAR file named derby*.jar. If your XWiki WAR doesn't have it in WEB-INF/lib you'll need to download it and copy it there. You can download it from the Derby web site or directly from the Maven Central Repository.
- Once this is done, you need to tell XWiki to use Derby and to tell it where the database files will be created. To do this, edit the WEB-INF/hibernate.cfg.xml file where you have expanded the XWiki WAR file and replace the matching properties with the following ones:
<property name="connection.driver_class">org.apache.derby.jdbc.EmbeddedDriver</property>
<property name="dialect">org.hibernate.dialect.DerbyDialect</property>
where [DATABASE_LOCATION] is where you wish to put the Derby database. For example /apps/xwikidb.
Now Derby doesn't support VARCHAR larger than 32K and Hibernate doesn't map large fields to correct Derby types (it should use BLOB and CLOB instead of VARCHAR). Thus we need to provide a modified HBM mapping file. Follow the instructions below.
For XWiki 1.1M2 and above
Use the following mapping definition in WEB-INF/hibernate.cfg.xml:
This definition should replace any other similar definition (except for the "feeds.hbm.xml" definition which is used for something else).
For XWiki 1.1M1
Place this
file in your WEB-INF/classes directory, rename it to "xwiki.derby.hbm.xml" and add the following mapping definition in WEB-INF/hibernate.cfg.xml:This definition should replace any other similar definition (except for the "feeds.hbm.xml" definition which is used for something else).
For XWiki 1.0 and lower
Place this
file in your WEB-INF/classes directory, rename it to "xwiki.derby.hbm.xml" and add the following mapping definition in WEB-INF/hibernate.cfg.xml:This definition should replace any other similar definition (except for the "feeds.hbm.xml" definition which is used for something else).