关于MyBatis框架

概念:MyBatis 是一款优秀的持久层框架,一个半 ORM(对象关系映射)框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生类型、接口和 Java 的 POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

MyBatis中,#{ } 和${ }区别?

#{  }

#{} 是占位符,预编译处理,Mybatis在处理#{}时,会将sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值;

使用#{}可以有效的防止SQL注入,提高系统安全性。

${}

${}是字符串替换,Mybatis在处理${}时,就是把${}替换成变量的值,

MyBatis编程步骤?

1、 创建SqlSessionFactory

2、 通过SqlSessionFactory创建SqlSession

3、 通过sqlsession执行数据库操作

4、 调用session.commit()提交事务

5、 调用session.close()关闭会话

MyBatis,resultType 和  resultMap区别?

如果数据库结果集中的列名和要封装实体的属性名完全一致的话用 resultType 属性;

如果数据库结果集中的列名和要封装实体的属性名有不一致的情况用 resultMap 属性,通过resultMap手动建立对象关系映射,resultMap要配置一下表和类的一一对应关系,所以说就算你的字段名和你的实体类的属性名不一样也没关系,都会给你映射出来

MyBatis中动态SQL 标签?

1. <if>if是为了判断传入的值是否符合某种规则,比如是否不为空.

2. <where> where标签可以用来做动态拼接查询条件,当和if标签配合的时候,不用显示的声明类型where 1 = 1这种无用的条件

3. <foreach> foreach标签可以把传入的集合对象进行遍历,然后把每一项的内容作为参数传到sql语句中.

4. <include> include可以把大量的重复代码整理起来,当使用的时候直接include即可,减少重复代码的编写;

5. <set>适用于更新中,当匹配某个条件后,才会对该字段进行跟新操作

MyBatis的缓存机制?

Mybatis有两级缓存,一级缓存是SqlSession级别的,默认开启,无法关闭;二级缓存是Mapper级别的,二级缓存默认是没有开启的,但是手动开启

1. 一级缓存:基础PerpetualCache的HashMap本地缓存,其存储作用域为Session,当Session flush或close之后,Session中的所有Cache就将清空

2. 二级缓存其存储作用域为Mapper(Namespace),使用二级缓存属性类需要实现Serializable序列化接口

3. 对于缓存数据更新机制,当某一个作用域(一级缓存Session/二级缓存Namespaces)的进行了C(增加)/U(更新)/D(删除)操作后,默认该作用域下所有select中的缓存将被clear.需要在setting全局参数中配置开启二级缓存,如下conf.xml配置

<setting>
    <setting name="cacheEnabled" value="true"/>  默认是false,关闭二级缓存
</setting>

当我们的配置文件配置了cacheEnabled=true时,就会开启二级缓存,二级缓存是mapper级别的,如果你配置了二级缓存,那么查询数据的顺序应该为:二级缓存→一级缓存→数据库

       mytabis从来只是写一个mapper 接口,写一个,xml文件,从来没写过实现类,利用asm 框架用它来在运行期间去动态的拼出一个代理类的字节码,可以随意控制代理类的class字节码的内容,动态代理再生成字节码的时候,在字节码的内部把切面增强的动作和目标动作做了结合,e.g. 把增强的动作放在目标动作之前,就是aop的前置通知

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis是一种基于Java的持久层框架,它可以将SQL语句和Java对象进行映射,使得程序员可以使用面向对象的方式来访问关系型数据库。MyBatis框架主要包括以下几个组件: 1. SqlSessionFactory:SqlSessionFactory是MyBatis框架的核心组件,它是一个线程安全的对象,用来创建SqlSession对象。 2. SqlSession:SqlSession是MyBatis框架中的一个会话对象,它提供了对数据库的所有操作方法,包括增、删、改、查等操作。 3. Mapper接口:Mapper接口是MyBatis框架中的一个重要组件,它定义了针对某个数据表的增、删、改、查等操作方法。 4. Mapper XML文件:Mapper XML文件是MyBatis框架中的另一个重要组件,它提供了针对某个数据表的SQL语句,包括增、删、改、查等操作。 MyBatis框架的执行流程如下: 1. 加载SqlSessionFactory:程序首先通过MyBatis的配置文件(mybatis-config.xml)来创建SqlSessionFactory对象。 2. 获取SqlSession:程序通过SqlSessionFactory来获取SqlSession对象。 3. 执行SQL语句:程序通过SqlSession对象来执行SQL语句,可以通过Mapper接口或Mapper XML文件来执行SQL语句。 4. 返回结果:程序执行完SQL语句后,MyBatis框架会将查询结果封装成Java对象并返回。 总的来说,MyBatis框架是一种轻量级的持久层框架,它可以使得程序员可以使用面向对象的方式来访问关系型数据库,从而提高程序的开发效率和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值