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
 
  
  
  
 
 
 
 
 