我的数据库中有一个名为"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
定律