How to get the name of the table GORM object is ma

2019-03-18 05:32发布

Say I have something like:

class Foo {
    static mapping = {
        table 'foo_table'
    }
}

How can I get the name of foo_table if I have a reference to an instance of this object?

标签: grails dns gorm
2条回答
兄弟一词,经得起流年.
2楼-- · 2019-03-18 05:51

JamesA's answer will work, but only if table name if defined explicitly, like in the question.

If you wish to get a table name whether or not it was specified in mapping, it can be done using SessionFactory:

def tableName = sessionFactory.getClassMetadata(Foo).tableName
查看更多
趁早两清
3楼-- · 2019-03-18 06:06

Import org.codehaus.groovy.grails.orm.hibernate.cfg.GrailsDomainBinder.

To get the table name from the domain class:

def tableName = GrailsDomainBinder.getMapping(Foo).table.name 

And to get the table name from an instance of the domain class:

def tableName = GrailsDomainBinder.getMapping(foo.class).table.name
查看更多
登录 后发表回答