摘自: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 ); } }}