摘自:http://www.mybatis.cn/archive…
MyBatis
MyBatis是一个优良的长久层框架,MyBatis的根本工作原理就是:先封装SQL,接着调用JDBC操作数据库,最初把数据库返回的表后果封装成Java类。
mybatis应用程序通过SqlSessionFactoryBuilder从mybatis-config.xml配置文件中构建出SqlSessionFactory,而后,SqlSessionFactory的实例间接开启一个SqlSession,再通过SqlSession实例取得Mapper对象并运行Mapper映射的SQL语句,实现对数据库的CRUD和事务提交,之后敞开SqlSession。如下图所示
(1)读取MyBatis的配置文件。mybatis-config.xml为MyBatis的全局配置文件,用于配置数据库连贯信息。
(2)加载映射文件。映射文件即SQL映射文件,该文件中配置了操作数据库的SQL语句,须要在MyBatis配置文件mybatis-config.xml中加载。mybatis-config.xml 文件能够加载多个映射文件,每个文件对应数据库中的一张表。
(3)结构会话工厂。通过MyBatis的环境配置信息构建会话工厂SqlSessionFactory。
(4)创立会话对象。由会话工厂创立SqlSession对象,该对象中蕴含了执行SQL语句的所有办法。
(5)Executor执行器。MyBatis底层定义了一个Executor接口来操作数据库,它将依据SqlSession传递的参数动静地生成须要执行的SQL语句,同时负责查问缓存的保护。
(6)MappedStatement对象。在Executor接口的执行办法中有一个MappedStatement类型的参数,该参数是对映射信息的封装,用于存储要映射的SQL语句的id、参数等信息。
(7)输出参数映射。输出参数类型能够是Map、List等汇合类型,也能够是根本数据类型和POJO类型。输出参数映射过程相似于JDBC对preparedStatement对象设置参数的过程。
(8)输入后果映射。输入后果类型能够是Map、List等汇合类型,也能够是根本数据类型和POJO类型。输入后果映射过程相似于JDBC对后果集的解析过程。
JDBC
JDBC四大外围对象
(1)DriverManager,用于注册数据库连贯
(2)Connection,与数据库连贯对象
(3)Statement/PrepareStatement,操作数据库SQL语句的对象
(4)ResultSet,后果集或一张虚构表
package Ring1270.pra.JDBC.Test;
import java.sql.*;
public class JDBCTest {
public static void main(String[] args) throws Exception {
Connection connection = null;
PreparedStatement statement = null;
ResultSet resultSet = null;
try {
// Registration driver
Class.forName("com.mysql.cj.jdbc.Driver");
// Get connection
connection = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/jt_db?serverTimezone=GMT%2B8",
"root",
"1111"
);
// Get transmitter
// Sent sql String sql = "select * from account";
statement = connection.prepareStatement(sql);
resultSet = statement.executeQuery();
// Deal rusult
while (resultSet.next()) {
int id = resultSet.getInt("id");
String name = resultSet.getString("name");
double money = resultSet.getDouble("money");
System.out.println(id + ":" + name + ":" + money);
}
}catch (Exception e) {
e.printStackTrace();
}finally {
// Release connection
if (resultSet != null) {
try {
resultSet.close();
}catch (Exception e) {
e.printStackTrace();
}finally {
resultSet = null;
}
}
if (statement != null) {
try {
statement.close();
}catch (Exception e) {
e.printStackTrace();
}finally {
statement = null;
}
}
if (connection != null) {
try {
connection.close();
}catch (Exception e) {
e.printStackTrace();
}finally {
connection= null;
}
}
}
}
}
MyBatis
MyBatis四大外围对象:
(1)SqlSession对象,该对象中蕴含了执行SQL语句的所有办法【1】。相似于JDBC外面的Connection 【2】。
(2)Executor接口,它将依据SqlSession传递的参数动静地生成须要执行的SQL语句,同时负责查问缓存的保护。相似于JDBC外面的Statement/PrepareStatement。
(3)MappedStatement对象,该对象是对映射SQL的封装,用于存储要映射的SQL语句的id、参数等信息。
(4)ResultHandler对象,用于对返回的后果进行解决,最终失去本人想要的数据格式或类型。能够自定义返回类型。
package Ring1270.pra.MyBatis;
import Ring1270.pra.MyBatis.pojo.Emp;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
public class MyBatisTest {
/** 练习1(疾速入门): 查问emp表中的所有员工, 返回一个List<Emp>汇合
* @throws IOException */
@Test
public void findAll() throws IOException {
//1.读取mybatis的外围配置文件(mybatis-config.xml)
InputStream in = Resources
.getResourceAsStream("mybatis-config.xml");
//2.通过配置信息获取一个SqlSessionFactory工厂对象
SqlSessionFactory fac =
new SqlSessionFactoryBuilder().build( in );
//3.通过工厂获取一个SqlSession对象
SqlSession session = fac.openSession();
//4.通过namespace+id找到要执行的sql语句并执行sql语句
List<Emp> list = session
.selectList("EmpMapper.findAll");
//5.输入后果
for(Emp e : list) {
System.out.println( e );
}
}
}
发表回复