1.什么是Mybatis(概念,作用,原理)
一个基于Java的持久层框架。。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java对象映射成数据库中的记录。。
2.如何使用Mybatis,两种方法,config主配置文件一样,mapper配置文件不同
配置主配置xml文件
要点:@properties中的resource的优先级更高 @在setting标签中创建健值对关系,键为autoMappingBehavior,来选择在使用resultMap时是否自动映射,值分为NONE(不映射,在数据库中的名字和bean中的名字不同时报错),PARTIAL(将自动映射结果除了那些有内部定义内嵌结果映射的),FULL- 自动映射所有
第一种方法:
配置mapper映射文件
操作sql语句
第二种方法:
配置mapper映射文件
创建接口,接口名字要和xml文件名一致,方法即为mapper配置文件中的id
创建该接口实例,调用其中的方法
3.动态sql语句的使用
要点:@foreach标签的使用,collection中为传递进来的list集合,item的值为取出来的单个元素 @使用#{}来取值 @下图open属性,separate属性,close属性===(,,)
要点:@使用if标签进行判断 @使用concat函数将多个字符串连接成一个字符串
要点:@rusultmap标签的使用(用来确保实体类中的属性名和数据库中的一致),在一个类中的属性为另一个类时使用association,下图即为在Good类中有type类,所以第一个resultmap返回Good,嵌套的resultmap返回Type类型,使用association把两个resultMap连接在一起,这种称为外部嵌套 @内部嵌套:可以直接在association中直接使用result标签进行映射,从而来实现内部嵌套
要点:@rusultmap标签的使用,在一个类中的属性为另一个类的集合时使用cllection标签,javaType为该属性的数据类型,ofType为该集合中的类
要点:@resultMap和statement的关联嵌套查询,使用resultMap和statement来进行数据的查询 @将一条需要连表的复杂的sql语句分成两条来写
在上一条sql语句中嵌套resultMap,再使用association标签连接另一个select标签,column属性为第一条sql语句查询出来的值
4.使用注解的方法代替mapper配置文件的配置
要点:@ @Param注解用于传递多个参数,其中的名字为别名,使用别名时需要和#{}中的值对应 @ 常用注解有@select,delete,update,insert,results,result,resultMap,param注解 @results,result要一起使用,相当于简单的字段映射 @resultMap则相当于嵌套使用
5.自定义注解
要点:@注解按来源分为,自定义注解,第三方注解,jdk的自带注解;按照运行机制分为,源注解,编译时注解,运行时注解 @使用@interface来自定义注解 @ Target指定注解能够使用的位置:ElementType.TYPE表示可以使用在类上 @ Retention指定注解在什么时候有用,常用runtime @Inherited规定注解是否可以继承,子类只能继承父类在类上使用的注解 @成员变量的数据类型有规定,只能是:基本数据类型,String,Annotation,枚举类 @成员变量可以有一个或者多个,也可以没有,没有的话该注解就起 标识作用 @注解的作用:标识和传递数据
6.sql语句构造器
7.一级缓存和二级缓存
定义:
一级缓存:同一个sqlsession,同一条sql语句,从一级缓存中取数据
二级缓存:@不同的sqlsession(在同一个namespace中),同一条sql语句
要点:@在setting中设置cacheEnabled的value为true @在想要使用二级缓存的sql标签中前加标签cache以及使用属性usecache @只有调用了close方法,才会将数据写入到二级存中 @在使用过程中执行增删改则会清除二级缓存,需要去数据库中重新获取。
8.逆向工程:把数据库中的表映射成java类文件
9.动态代理设计模式
可以不修改原来对象的基础上添加新功能
分为:
被代理类(需要增加新功能的类):被代理类必须实现一个街口,任意接口
代理类(实现功能的增强)
步骤:实现InvocationHandler接口,通过构造方法传入被代理类对象。。。重写invoke方法,通过method.invoke(被代理类, args)来调用被代理类的方法,并给该方法前后添加新的功能
代理类对象(具有新功能的被代理类对象)