我是靠谱客的博主 迷人棒棒糖,最近开发中收集的这篇文章主要介绍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<Student> selectStudent(@Param("personName") String name,@Param("personAge") int age);

mapper文件:

<select id="selectMultiParam" resultType="com.bjpowernode.domain.Student">

select id,name,email,age from student where name=#{personName} or age=#{personAge}

</select>

(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的条件位置上加上“%”

最后

以上就是迷人棒棒糖为你收集整理的MyBatis框架概述的全部内容,希望文章能够帮你解决MyBatis框架概述所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部