先來假設這樣一個問題:若是數據庫裏面有一個用戶表和一個做家表,那麼當要添加一條數據到做家表中時,做家表的id必須是用戶表中的其中一個id,由於做家必定也要是一個用戶。這時就涉及到事務處理。java
在上一篇博客的基礎上,同時添加一我的的信息到用戶表和做家表,若是失敗則須要事務回滾sql
在pojo包中新建實體類 AuthorInfo.java數據庫
1 package com.jike.book.pojo; 2 3 public class AuthorInfo { 4 5 private int id; 6 private UserInfo userInfo; 7 private String realname; 8 private int age; 9 public int getId() { 10 return id; 11 } 12 public void setId(int id) { 13 this.id = id; 14 } 15 public UserInfo getUserInfo() { 16 return userInfo; 17 } 18 public void setUserInfo(UserInfo userInfo) { 19 this.userInfo = userInfo; 20 } 21 public String getRealname() { 22 return realname; 23 } 24 public void setRealname(String realname) { 25 this.realname = realname; 26 } 27 public int getAge() { 28 return age; 29 } 30 public void setAge(int age) { 31 this.age = age; 32 } 33 34 35 }
在map包中建立author.xml的映射xml文件apache
1 <?xml version="1.0" encoding="UTF-8" ?> 2 3 4 <!DOCTYPE mapper 5 PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" 6 "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 7 8 <mapper namespace="/"> 9 10 <insert id="insert_toauthor" parameterType="AuthorInfo"> 11 insert into author (id,realname,age) values(#{userInfo.id},#{realname},#{age}) 12 </insert> 13 14 </mapper>
在MyBatisConfig.xml文件中添加:session
<typeAlias alias="AuthorInfo" type="com.jike.book.pojo.AuthorInfo"/>
以及mybatis
<mapper resource="com/jike/book/map/author.xml"/>
建立測試類:app
1 package com.jike.book.test; 2 3 import java.io.Reader; 4 import java.util.List; 5 6 import org.apache.ibatis.io.Resources; 7 import org.apache.ibatis.session.SqlSession; 8 import org.apache.ibatis.session.SqlSessionFactory; 9 import org.apache.ibatis.session.SqlSessionFactoryBuilder; 10 11 import com.jike.book.pojo.AuthorInfo; 12 import com.jike.book.pojo.UserInfo; 13 14 public class Test8 { 15 16 public static void main(String[] args) { 17 String resource = "com/jike/book/map/MyBatisConfig.xml"; 18 Reader reader = null; 19 SqlSession session = null; 20 try{ 21 reader = Resources.getResourceAsReader(resource); 22 }catch(Exception e){ 23 e.printStackTrace(); 24 } 25 SqlSessionFactory sqlMapper = new SqlSessionFactoryBuilder().build(reader); 26 session = sqlMapper.openSession(); 27 28 try{ 29 UserInfo u = new UserInfo(); 30 u.setUserName("uvi"); 31 u.setPassword("uvi"); 32 session.insert("insert", u); 33 34 AuthorInfo au = new AuthorInfo(); 35 au.setAge(23); 36 au.setUserInfo(u); 37 au.setRealname("pol"); 38 session.insert("insert_toauthor", au); 39 session.commit(); 40 }catch(Exception e){ 41 e.printStackTrace(); 42 session.rollback();//若是失敗,則事務回滾 43 }finally{ 44 session.close(); 45 } 46 } 47 48 }
執行成功。測試