JPA是描述对象-关系表的映射关系,将运行期实体对象持久化到数据库中,提出以面向对象方式操作数据库的思想。

Hibernate框架核心思想是ORM-实现自动的关系映射。缺点:由于关联操作提出Hql语法。执行CRUD时产生大量冗余的sql,性能较低

mybatis继承Hibernate优点,使用通用mapper插件 实现JPA的思想操作数据库

通用mapper:

一、配置通用mapper插件

<!-- 通用Mapper插件 -->
		<plugin interceptor="com.github.abel533.mapperhelper.MapperInterceptor">
			<!--主键自增回写方法,默认值MYSQL,详细说明请看文档 -->
			<property name="IDENTITY" value="MYSQL" />
			<!--通用Mapper接口,多个通用接口用逗号隔开 -->
			<property name="mappers" value="com.jt.common.mapper.SysMapper" />
		</plugin>

  

二、通过注解的方式将POJO对象与表进行关联,之后可以通过通用Mapper方式进行操作.

详细步骤:实体类上加注解@Table(name="表名"),id属性加@Id标识主键信息,如果是自增则标识@GeneratedValue(strategy=GenerationType.IDENTITY)

三、通用mapper的流程

1、从serviceImpl实现类里面读取到调用的mapper的方法

2、通过反射获取找到该mapper类

3、获取当前mapper的父级接口,并判断该父级接口是不是泛型

4、从泛型中获取泛型的类型是哪个类

5、找到该类,并查看该类上面的注解,读取注解信息,获取name属性对应的数据库表名

6、编写sql实现数据查询

 

 public SqlNode TestFindCount(MappedStatement ms){
    	try {
    	//1.获取客户端调用的方法 com.jt.manage.mapper.ItemMapper.findTextCount()
    	String methodPath = ms.getId();
    	
    	//2.获取ItemMapper的字符串
    	String targetPath = methodPath.substring(0, methodPath.lastIndexOf("."));
    	
    	//3.获取ItemMapper对象
    	Class<?> targetClass = Class.forName(targetPath);
    	
    	//4.获取ItemMapper的父级接口 由于接口是可以多继承的
    	Type[] types = targetClass.getGenericInterfaces();
    	
    	//5.获取SysMapper
    	Type targetType = types[0];
    	
    	//判断该类型是否为泛型 SysMapper<Item>
    	if(targetType instanceof ParameterizedType){
    		//表示当前接口是一个泛型,并且获取泛型参数
    		ParameterizedType parameterizedType = (ParameterizedType) targetType;
    		
    		//SysMapper<T,V,K>   获取泛型的全部参数
    		Type[] supers =  parameterizedType.getActualTypeArguments();
    		
    		//表示成功获取第一个参数
Class<?> targetMethodClass = (Class<?>) supers[0];
    		
    		//判断Class不能为空
    		if(targetMethodClass !=null){
    			
    			//判断该类中是否含有注解
    			if(targetMethodClass.isAnnotationPresent(Table.class)){
    				//获取目标对象的注解
    				Table table = targetMethodClass.getAnnotation(Table.class);
    				
    				//获取表名
    				String tableName = table.name();
    				
    				//定义查询sql语句
    				String sql = "select count(*) from "+tableName;
    				
    				//定义sqlNode对象
    				SqlNode sqlNode = new StaticTextSqlNode(sql);
    				
    				return sqlNode;
    			}	
    		}
    	}
    	
		} catch (ClassNotFoundException e) {
			
			e.printStackTrace();
		}	
    	return null;	
    }

 

  

说明:

targetClass.getGenericInterfaces() 表示获取接口的父级类型

java.lang.reflect.ParameterizedType; 泛型类型的接口

java.lang.reflect.Type;  接口的超类Type