MyBatis的事務處理

 

    先來假設這樣一個問題:若是數據庫裏面有一個用戶表和一個做家表,那麼當要添加一條數據到做家表中時,做家表的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 }


執行成功。測試

相關文章
相關標籤/搜索