These warnings are true, but they are not PostgreSQL specific. GORM uses the name of the domain class as table names and the name of the properties as column names. And if you use complex relationships, it will even create table names with concatenated domain class names.
This will result in two problems:
- Some databases like oracle and PostgreSQL are picky about table and column names which are reserved keywords like SELECT, TABLE, FROM, USER etc. Grails will try to create those tables and columns but will fail with a database exception. This is very ugly when you develop with a database which is not so picky and deploy to another one which will crash your app.
- There are contraints regarding the length of table names. So if you create a BooksWithHsitoricalValue Domain which references a AuthorsWhoDiedALongTimeAgo Domain in a many-to-many fashion, it is likely that you will scratch this limit. But the good news is that this will not happen too often :-)
The solution is to create a ImprovedNamingStrategy and tell hibernate to use it: http://grails.org/doc/latest/guide/GORM.html#customNamingStrategy
Create a class like the following in your /src/groovy folder:
package com.blogspot.parzeval import org.hibernate.cfg.ImprovedNamingStrategy import org.hibernate.util.StringHelper import org.codehaus.groovy.grails.commons.* class SafeNamingStrategy extends ImprovedNamingStrategy { def config = ConfigurationHolder.config String classToTableName(String className) { config.dataSource.tablePrefix + StringHelper.unqualify(className) } String propertyToColumnName(String propertyName) { config.dataSource.columnPrefix + StringHelper.unqualify(propertyName) } }
and configure your prefixes in your DataSource.groovy:
dataSource { tablePrefix = 'tbl_' columnPrefix = 'col_' }
A better solution would be if hibernate would handle those reserved keywords in the right way (most databases allow you to set column and table names in quotation marks or something equal). But I haven't found a switch for that yet :-(
PS: there seems to be a setting for hibernate 3.5+ to automatically escape all column and table names:
hibernate.globally_quoted_identifiers=true
Unfortunately, I couldn't get it to work. And there seems to be a reason for not beeing a default setting...
No comments:
Post a Comment