我有2个带有mysql的grails的表格
说A和B
我想在这里实现的方案是:
(1)A的实例可以有零个/一个/多个B实例。
(2)当删除实例A时,必须删除所有相关的B。
(3)B的每个实例必须只与A的一个实例相关联。
(4)A知道B,但B不知道A。
条件号4不是强制性的。
从上面的信息看来:从A到B的单向一对多
目前我正在做的是:(从here获取帮助)
class A
{
String name
Set bs=[]
static hasMany=[bs:B]
}
Class B
{
String name
}
B b=new B(name:'bname')
b.save()
A a=new A(name:'aname')
a.addToBs(b)
a.save()
保存两个条目时,(B正在保存,但A未保存)我正在使用addTo并获取错误没有方法的签名addToBs()
如果我在某个地方出错,请帮助我并纠正我。
答案 0 :(得分:7)
class A
{
String name
static hasMany=[bs:B] //by default bs are Set. no need of explicit declaration
}
Class B
{
String name
static belongsTo = A //when delete a it's b also will get deleted
}
B b1=new B(name:'bname1')
B b2=new B(name:'bname11')
B b3=new B(name:'bname2')
A a=new A(name:'aname1')
A a2=new A(name:'aname2')
a.save(flush:true)
a2.save(flush:true)
a.addToBs(b1)
a.addToBs(b2)
a2.addToBs(b3)
a.save(flush:true)
a2.save(flush:true)
无需保存b
的实例。当我们将b
实例添加到b's
上a
的集合中时,当我们保存b
的实例时,它会自动保存a
的实例。