(Quick Reference)
indexColumn
Purpose
Customizes the index column definition of an indexed collection such as a
List
or
Map
Examples
class Neo {
static hasMany = [matrix:Integer]
static mapping = {
matrix indexColumn:[name:"the_matrix", type:Integer]
}
}def neo = new Neo()
neo.matrix = [ (1): 30,
(2): 42,
(3): 23 ]
neo.save(flush:true)
Description
Usage:
association_name(indexColumn:map)
Arguments:
name
- The name of the column as a String
type
(optional) - The Hibernate type.
sqlType
(optional) - The underlying SQL type
enumType
(optional) - The enum type in for type-safe Enum properties. Either ordinal
or string
.
index
(optional) - The index name
unique
(optional) - Whether it is unique or not
length
(optional) - The length of the column
precision
(optional) - The precision of the column
scale
(optional) - The scale of the column
By default when mapping an indexed collection such as a
Map
or
List
the index is stored in a column called
association_name_idx
which is an
integer
type in the case of lists and a String in the case of maps. You can alter how the index column is mapped using the
indexColumn
argument:
static mapping = {
matrix indexColumn:[name:"the_matrix", type:Integer]
}