我正在尝试创建一个insert语句,允许我在一个块中插入多个表但没有取得任何成功。这是一个例子:
public class Parent {
String parentId;
List<Child> children;
...getters and setters...
}
public class Child {
String childId;
List<Toy> toys;
...getters and setters...
}
public class Toy {
String toyId;
String color;
...getters and setters...
}
create table TOY (TOY_ID varchar(10), COLOR varchar(10), CHILD_ID varchar(10),
primary key(TOY_ID), foreign key (CHILD_ID) references CHILD(CHILD_ID));
create table CHILD (CHILD_ID varchar(10), PARENT_ID varchar(10),
primary key(CHILD_ID), foreign key (PARENT_ID) references PARENT(PARENT_ID));
create table PARENT (PARENT_ID varchar(10), primary key(PARENT_ID));
<resultMap id="ToyResult" type="Toy">
<id property="toyId" column="TOY_ID"/>
<result property="color" column="COLOR"/>
</resultMap>
<resultMap id="ChildResult" type="Child">
<id property="childId" column="CHILD_ID"/>
<collection property="toys" ofType="Toy" resultMap="ToyResult"/>
</resultMap>
<resultMap id="ParentResult" type="Parent">
<id property="parentId" column="PARENT_ID"/>
<collection property="children" ofType="Child" resultMap="childResult"/>
</resultMap>
我想知道是否可以执行以下插入映射:
<insert id="insertParentData" parameterType="Parent">
insert into PARENT(PARENT_ID) values(#{parentId});
insert into CHILD(CHILD_ID, PARENT_ID) values
<foreach collection="children" item="childItem" index="index0" separator=",">
(#{childItem.childId}, #{parentId})
</foreach>;
insert into TOY(TOY_ID, COLOR, CHILD_ID) values
<foreach collection="children" item="childItem" index="index0" separator=",">
<foreach collection="childItem.toys" item="toyItem" index="index1" separator=",">
(#{toyItem.toyId}, #{toyItem.color}, #{childItem.childId})
</foreach>
</foreach>
</insert>
我收到一条错误消息,指出我的SQL语法有错误。它指出了insert into CHILD
行。
如果无法使用此插入方法,您会如何建议我映射插入语句?我可以创建ParentMapper,ChildMapper和ToyMapper xml文件,在我的父数据访问对象中,我将有三个插入调用,每个调用使用不同的映射器插入到不同的表中。
感谢您的帮助。
答案 0 :(得分:0)
每个查询都必须有一个元素。也许你可以创建一个“insertParent”java方法,在父插入之后,为他的孩子调用一个“insertChildren”方法,递归调用“insertToys”方法。
答案 1 :(得分:0)
我通过将大插件分成三个单独的插件并在我的DAO中调用它来解决了这个问题。