前面分享了一些学习grails的心得,但是grails的知识还远不止这些,这次整理了一点有关grails一对多双向关联关系的知识。我觉得这种关联用的地方太多了,这次准备的例子是城市和区域的相关例子。
1.领域模型
class CityInfo {
static hasMany = [area:AreaInfo]
static fetchMode = [area:'lazy']
Integer id;
String name;
String code;
static mapping = {
table 'm_city'
}
}
hasMany代表CityInfo是一的一方,fetchMode配置的是抓取模式,这里使用的是懒加载(默认)。要注意的是因为我的数据库中对于的表为m_city;如果不配置表示对于的表为CityInfo
class AreaInfo {
static belongsTo=[city:CityInfo]
Integer id;
String name;
String areaCode;
static mapping = {
table 'm_area'
areaCode column:'areaCode'
city column: 'cityId'
}
}
belongsTo配置的是多的一方,也就是是说AreaInfo中存在一个外键名称是city.综合上面的可以看出CityInfo是主表,而AreaInfo是从表。这里有点奇怪的是areaCode映射出来的列名为area_code为了方便我顺便把要映射的列名改掉了
2.创建控制器和视图
这个步骤就不说了,直接使用intellij IDE就可以自动为我们生成控制器和视图了。先来看看生成的控制器能不能用
这说明生成的控制器没有问题,下面添加一个方法用来保存城市和区域信息
//保存城市和区域信息
@Transactional
def saveCityAndArea(){
def a=new AreaInfo()
a.setName("西山区")
a.setAreaCode("XS")
//Set<AreaInfo> s=new HashSet<AreaInfo>()
// s.add(a)
def c=new CityInfo()
c.setName("昆明市")
c.setCode("KM")
c.save()
a.setCity(c)
a.save()
render "数据保存成功"
}
这里要注意的是如果是关系型数据库,那么就不要忘记配置事务。遗憾的是级联保存用这个框架貌似有问题,另外要注意的是grail默认的级联保存和更新,但是不会级联删除除非配置的是双向关联(也配置了belongsTo).
接下来我也写了个方法,用来查询对于城市的区域信息:
//查询城市信息
def queryCity(){
def city=CityInfo.findById(params.id)
Set<AreaInfo> area=city.getArea()
Iterator<AreaInfo> it=area.iterator()
def buf=new StringBuffer()
while(it.hasNext()){
AreaInfo info=it.next()
buf.append(info.getName()+",")
}
render buf.toString()
}
要注意的是findBy是一个动态的查询方法,findById就表示通过Id来查询城市信息