myBatis工作流程
我们通过一个向数据库中插入一条数据记录的例子来了解一些myBatis的工作流程
- 数据库表的描述如下,创建脚本很简单,这里就不写了
下面开始写代码
第一步:写数据表对应的实体类Student.java
package com.cxspace.bean;
public class Student {
private int id;
private String s_name;
private int s_age;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getS_name() {
return s_name;
}
public void setS_name(String s_name) {
this.s_name = s_name;
}
public int getS_age() {
return s_age;
}
public void setS_age(int s_age) {
this.s_age = s_age;
}
@Override
public String toString() {
return "Student [id=" + id + ", s_name=" + s_name + ", s_age=" + s_age
+ "]";
}
public Student(int id, String s_name, int s_age) {
super();
this.id = id;
this.s_name = s_name;
this.s_age = s_age;
}
public Student(){
}
}
第二步:写实体类的映射配置文件StudentMapper.xml
<mapper namespace="com.cxspace.bean.Student">
<insert id="addStudent" parameterType="com.cxspace.bean.Student">
insert into student values (#{id},#{s_name},#{s_age})
insert>
mapper>
- 在里面我们配置了一条向数据库插入数据记录的sql语句,并用ognl表达式把java代码中对象的值传入语句。
第三步:写总的配置文件Configuration.xml文件
<configuration>
<environments default="mysql_development">
<environment id="mysql_development">
<transactionManager type="JDBC">
<property name="" value=""/>
transactionManager>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://127.0.0.1:3306/mybatis"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
dataSource>
environment>
environments>
<mappers>
<mapper resource="com/cxspace/bean/StudentMapper.xml"/>
mappers>
configuration>
第四步:写mybatis工具类,维护数据库连接
package com.cxspace.db;
import java.io.IOException;
import java.io.Reader;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
public class MyBatisUtil {
private static ThreadLocal threadLocal = new ThreadLocal();
private static SqlSessionFactory sqlSessionFactory;
static{
try {
Reader reader = Resources.getResourceAsReader("com/cxspace/config/Configuration.xml");
sqlSessiOnFactory= new SqlSessionFactoryBuilder().build(reader);
} catch (IOException e) {
e.printStackTrace();
}
}
private MyBatisUtil(){
}
public static SqlSession getSqlSession(){
SqlSession sqlSession = threadLocal.get();
if (sqlSession == null) {
sqlSession = sqlSessionFactory.openSession();
threadLocal.set(sqlSession);
}
return sqlSession;
}
public static void closeSqlSession(){
SqlSession sqlSession = threadLocal.get();
if (sqlSession != null) {
sqlSession.close();
threadLocal.remove();
}
}
}
第五步:写StudentDao.java 对数据具体操作
package com.cxspace.dao
import java.util.List
import javax.jms.Message
import org.apache.ibatis.session.SqlSession
import com.cxspace.bean.Student
import com.cxspace.db.MyBatisUtil
public class StudentDao {
public void add(Student student) throws Exception{
SqlSession sqlSession = null
try {
sqlSession = MyBatisUtil.getSqlSession()
//事务开始(默认就开始了)
//读取StdentMapper.xml配置的SQL语句
int i = sqlSession.insert("com.cxspace.bean.Student.addStudent",student)
System.out.println("这次操作影响了:"+i+"行")
//事务提交
sqlSession.commit()
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace()
//事务回滚
sqlSession.rollback()
throw(e)
}finally{
MyBatisUtil.closeSqlSession()
}
}
}
第六步:测试
package com.cxspace.test;
import com.cxspace.bean.Student;
import com.cxspace.dao.StudentDao;
public class TestCRUD {
public static void main(String[] args) throws Exception {
StudentDao studentDao = new StudentDao();
Student student = new Student();
student.setId(666);
student.setS_name("xyz");
student.setS_age(29);
studentDao.add(student);
}
}
最后测试结果
控制台
数据库
最后,让我们对整个流程做一个总结,看看执行这样一条语句,mybatis做了什么。
数据库事务(Database Transaction) ,是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。 事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源。通过将一组相关操作组合为一个要么全部成功要么全部失败的单元,可以简化错误恢复并使应用程序更加可靠。一个逻辑工作单元要成为事务,必须满足所谓的ACID(原子性、一致性、隔离性和持久性)属性。事务是数据库运行中的一个逻辑工作单位,由DBMS中的事务管理子系统负责事务的处理。