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
mapper文件:
select id,name,email,age from student where name=#{personName} or age=#{personAge}
(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的条件位置上加上“%”