MyBatis框架概述

1.MyBatis框架:

MyBatis解决的主要问题

减轻使用JDBC的复杂性,不用编写重复的创建Connection,Statement;不用编写关闭资源代码。直接使用Java对象,表示结果数据。让开发者专注SQL的处理。其他分心的工作由MyBatis代劳。

MyBatis可以完成:

(1)注册数据库的驱动,例如Class.forName("com.mysql.jdbc.Driver")

(2)创建JDBC中必须使用的Connection,Statement,ResultSet对象;

(3)从xml中获取SQL,并执行SQL语句,把ResultSet结果转换成Java对象

2.MyBatis对象分析

Sqlsession,SqlsessionFactory等

(1)Resource类

Resource类,顾名思义就是资源,用于读取资源文件。其中有很多放大通过加载并解析资源文件,返回不同类型的IO流对象。

(2)SqlSessionFactoryBuilder类

SqlsessionFactory的创建,需要使用户SqlSessionFactoryBuilder对象的build()方法。由于Sqlsession FactoryBuilder对象在创建完工厂对象或,就完成了其历史使命,即可被销毁。所以,一般会将该SqlSessionFactoryBuilder对象创建为一个方法内的局部对象,方法结束,对象销毁。

(3)SqlSessionFactory接口

SqlSessionFactory接口对象是一个重量级对象(系统开销大的对象),是线程安全的,所以一个应用只需要一个该对象即可。创建SqlSession需要使用SqlSessionFactor接口的openSession()方法。

(a)openSession(true):创建衣蛾有自动提交功能的SqlSession

(b)openSession(false):创建一个非自动提交功能的SqlSession,需要手动提交;

(c)openSession():同openSession(false)

(4)SqlSession接口

SqlSession接口对象用于持久化操作。一个SqlSession对应着一次数据库会话,一次会话以SqlSession 对象的创建开始,以SqlSession对象的关闭结束。

  SqlSession接口对象是线程不安全的,所以每次数据库会话结束前,需要马上调用其close()

方法将其关闭。再次需要会话,再次创建。SqlSession在方法内部创建,使用完毕后关闭

3.MyBatis传递参数

(1)一个简单参数;
(2)多个参数-使用@Param

当Dao接口方法多个参数,需要通过名称使用参数。在方法形参前面加入@Param("自定义参数名"),mapper文件使用#{自定一参数名}

例如定义List selectStudent(@Param("personName") String name,@Param("personAge") int age);

mapper文件:

(3)多个参数-使用对象

使用java对象传递参数,java的属性值就是sql需要的参数值。每一个属性就是一个参数。

语法格式:#{property,javaType=java中数据类型名,jdbcType=数据类型名称}

javaType,jdbcType的类型MyBatis可以检测出来,一般不需要设置。常用格式#{property}

(4)封装MyBatis输出结果

(a)resultType:执行SQL得到ResultSet转换的类型,使用类型的完全限定名或别名。注意如果返回的是集合,那应该是设置为集合包含的类型,而不是集合本身。resultType和resultMap不能同时使用

(5)模糊like

模糊查询的实现有两种方式,一是java代码中给查询数据上加“%”;二是在mapper文件sql的条件位置上加上“%”

你可能感兴趣的:(java,mybatis,java,数据库)