Mybatis基础详解

0. 开发

  1. jdbc开发:pojo实体类xxx.java,xxx.xml映射文件,写sql,sqlmapconfig.xml加载,action调用
  2. 原生dao开发:实体类,dao接口,daoimpl调用方法xxx.xml文件中sql,action中调用imlp方法
    2.1 原生dao:spring配置文件中指定dao实现类 。dao实现类需继承sqlsessiondaosupport超类 。不需手动close会话
    2.2 包扫描
  3. mapper动态代理开发:xxx.java实体类,sqlmapconfig配置连接池和加载mapper文件。xxxmapper.xml写sql语句和映射,xxxmapper.java写接口,再有action调用。
    3.1 自动配置,实体类和表字段一致
    3.2 手动配置,设映射,指定表中字段和pojo类属性,用association标签。 集合只能手动,collection标签.
    3.3 加载配置文件是如:value="classpath:SqlMapConfig.xml,spring的配置文件需要加classpath,mybatis的中的不加spring和mybatis整合 :会话工程交由spring管理.

1. #和$的区别

  • #相当于对数据 加上 双引号,$相当于直接显示数据
  • #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号。如:order by #user_id#,如果传入的值是111,那么解析成 sql 时的值为 order by "111", 如果传入的值是 id,则解析成的 sql 为 order by "id".
  • $传入的数据直接显示生成在 sql 中。如:order by $ user id$,如果传入的值是 111,那么解析成 sql 时的值为order by 111, 如果传入的值是 id,则解析成的 sql 为 order by id.
  • '#'方式能够很大程度防止 sql 注入。$方式无法防止 Sql 注入。
  • $方式一般用于传入数据库对象,例如传入表名.
  • 一般能用’#'的就别用$.

2. Mybatis 的编程步骤

创建 SqlSessionFactory
通过 SqlSessionFactory 创建 SqlSession
通过 sqlsession 执行数据库操作
调用 session.commit()提交事务
调用 session.close()关闭会话

3. JDBC 编程不足之处,MyBatis如何解决

  • 数据库链接创建、释放频繁造成系统资源浪费从而影响系统性能,如使用数据库链接池可解决此问题。

解决:在 SqlMapConfig.xml 中配置数据链接池,使用连接池管理数据库链接。

  • Sql 语句写在代码中造成代码不易维护,实际应用 sql 变化的可能较大,sql 变动需要改变 java 代码。

解决:将 Sql 语句配置在 XXXXmapper.xml 文件中与 java 代码分离。

  • 向 sql 语句传参数麻烦,因sql 语句的 where 条件不一定,可多可少,占位符需和参数一一对应。

解决: Mybatis 自动将 java 对象映射至 sql 语句。

  • 对结果集解析麻烦,sql 变化导致解析代码变化,且解析前需要遍历,如果能将数据库记录封装成 pojo 对象解析比较方便。

解决:Mybatis 自动将 sql 执行结果映射至 java 对象。

4. 使用 MyBatis 的 mapper 接口调用时的要求

  1. Mapper 接口方法名和 mapper.xml 中定义的每个 sql 的 id 相同
  2. Mapper 接口方法的输入参数类型和 mapper.xml 中定义的每个 sql 的 parameterType 的类型相同
  3. Mapper 接口方法的输出参数类型和 mapper.xml 中定义的每个 sql 的 resultType 的类型相同
  4. Mapper.xml 文件中的 namespace 即是 mapper 接口的类路径。

5. 一级缓存与二级缓存

  • 一级缓存: 基于 PerpetualCache 的 HashMap 本地缓存,其存储作用域为 Session,当 Session flush 或close 之后,该 Session 中所有 Cache 将清空。
  • 二级缓存与一级缓存其机制相同,默认采用PerpetualCache,HashMap 存储,不同在于其存储作用域为Mapper(Namespace),且可自定义存储源,如Ehcache。作用域为 namespance是指对该 namespance 对应的配置文件中所有的 select 操作结果都缓存,这样不同线程之间就可以共用二级缓存。

二级缓存可以设置返回的缓存对象策略:当 readOnly="true"时,表示二级缓存返回给所有调用者同一个缓存对象实例,可update 获取的缓存实例,但可能会造成其他调用者出现数据不一致(因所有调用者调用同一个实例)。
当 readOnly="false"时,返回给调用者的是二级缓存总缓存对象的拷贝,即不同调用者获取的是缓存对象不同的实例,这样调用者对各自的缓存对象的修改不会影响到其他调用者,即安全的,所以默认是 readOnly=“false”;

  • 对于缓存数据更新机制,当某一个作用域(一级缓存 Session/二级缓存 Namespaces)的进行了 C/U/D 操作后,默认该作用域下所有 select 中的缓存将被 clear。

6. MyBatis 在 insert 插入操作时返回主键 ID

  • 数据库为 MySql 时:

keyProperty表示返回的 id 要保存到对象的那个属性中,“useGeneratedKeys”表示主键 id 为自增长模式。MySQL 中做以上配置就 OK 了

  • 数据库为 Oracle 时:

Oracle没自增长一说,只有序列这种模仿自增的形式,不能使用“useGeneratedKeys”属性。可将 ID 获取并赋值到对象的属性中,insert 插入操作时正常插入 id。

7.与spring整合的方式

####1. 采用MapperScannerConfigurer,将会查找类路径下的映射器并自动将它们创建成MapperFactoryBean。

spring-mybatis.xml:
dao类
####2. 采用接口org.apache.ibatis.session.SqlSession的实现类org.mybatis.spring.SqlSessionTemplate。

  • mybatis中, sessionFactory可由SqlSessionFactoryBuilder来创建。MyBatis-Spring 中,使用了SqlSessionFactoryBean来替代。SqlSessionFactoryBean有一个必须属性dataSource,另外还有个通用属性configLocation(指定mybatis xml配置文件路径)。
    ####3. 采用抽象类org.mybatis.spring.support.SqlSessionDaoSupport提供SqlSession。
  • 主要是在dao层,继承SqlSessionDaoSupport
    ####4. 采用数据映射器(MapperFactoryBean)的方式

8. Mybatis如何防止 sql 注入?mybatis 拦截器

  • Mybatis 使用#{}经过预编译的,是安全的,防止 sql 注入。
  • Mybatis 拦截器只能拦截四种类型的接口:Executor、StatementHandler、ParameterHandler 和 ResultSetHandler。

这是在 Mybatis 的 Configuration 中写死了的,如拦截其他接口要重写 Mybatis的Configuration。Mybatis可对这四个接口中所有方法进行拦截。Mybatis拦截器常被用来进行分页处理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值