我的领域类看起来是这样的:如何让Grails将我的字符串字段映射到Clob?
package com.initech.tps
class Foo
{
String stuff
static mapping = {
// mapping to a legacy table as opposed to letting Grails create it
table name: 'FOO', schema: 'TPS'
id generator: 'sequence', params: [sequence: 'MY_SEQ'],
column: 'FOO_ID', sqlType: 'integer'
foo column: 'STUFF'
}
static constraints = {
stuff(nullable: true, maxSize: 40000)
}
}
我下的印象的Grails会想出使用CLOB而不是基于我传递的最大范围约束一个足够大的值VARCHAR,而不是我弄在控制台此错误消息:
org.hibernate.HibernateException: Wrong column type in FOO for column STUFF.
Found: clob, expected: varchar(40000)
我需要在映射的明确则sqlType?我尝试使用不同的maxSize值,并将其完全保留,没有任何区别。另外加入sqlType: clob
或不起作用。
我在Grails 1.3.7上使用IBM DB2-Express。
这将是做这件事,我猜。我真的很想看到一个答案,它允许我在域对象中使用一个字符串。必须有一个用户类型。 – 2012-02-14 02:03:57