检索数据库grails中的整行



我的数据库中有一个名为"District"的表:

+----+---------+-------------+----------+------+------------------------------------------------+-----------+
| id | version | description | homepage | logo | name                                           | region_id |
+----+---------+-------------+----------+------+------------------------------------------------+-----------+

所以,在我的控制器上,我有:

def show = {
        def districtInstance = District.get(params?.id)
        println districtInstance
        println params
        if(!districtInstance){
            flash.message = "${message(code: 'default.not.found.message', args: [message(code: 'district.label', default: 'District'), params.id])}"
            redirect(action : "list", params?.id)
        }
        else{
            [districtInstance : districtInstance]
        }
    }

当我期待看到整排:

| 71 |       0 | bogus  |          |      | bogus                                      |         4 |

我只看到:

bogus

在控制台上。如何访问整排?(特别是districtInstance.region_id?)

println districtInstance只打印toString()方法的输出。使用println districtInstance?.dump()可以查看包括所有类字段在内的更多输出。但是,它看起来不像数据库视图,因为它是Groovy对象,而不是数据库查询结果。

根据问题更新:如果你需要region_id,你可以通过districtInstance.regionId获得它,这不需要额外的数据库调用。

println districtInstance?.region.id

在Groovy和一般的面向对象语言中,您可以navegate类属性,但您应该了解Demeter

定律

最新更新