Mybatis的代理模式

我们在使用Mybtis操作数据库的时候,以前经常要先写一个操作数据库的接口,把我们所需要的操作的方法先写出来,然后再去写实现类把方法具体实现,可是学过代理模式的人会知道动态代理可以自动帮我们去生成实现类,然而Mybatis框架里面已经帮我们写好了动态代理,它使用的jdk的动态代理,这样我们可以不要去写实现类如以下的代码

java 复制代码
public interface CatMapper {

    Cat getin(int id);

    List<Cat> getinadd(int id);

    int getdel(int id);


}

我们可以直接这样把接口写好实体类通过Mybatis框架自动生成,测试代码可以直接这样写

java 复制代码
   @Test
    public void test2(){
        SqlSession sqlSession = dupgjl.getSqlSession();
        //通过动态代理机制,创建一个 CatMapper 接口的代理对象
        CatMapper mapper = sqlSession.getMapper(CatMapper.class);
        Cat getin = mapper.getin(5);
        System.out.println(getin);
    }

但我们需要注意一些细节,可能会有人想到,我们就写一个接口然后通过 sqlSession.getMapper

方法来直接调用接口中的方法,那么我们怎么能确定这个对象它去调了这个方法所要运行的sql语句呢,因为我们一直在这里写java代码,没有去考虑配置文件里面的事情,所有这个方法很好用,但它要注意一些事情,就是我们的配置文件需要 规范的填写

XML 复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.example.CatMapper">
    <select id="getin" resultType="org.example.Cat">
        select id, car_num as num, brand, guide_price as price, produce_time as date, car_type as type from t_cat where id = #{c}
    </select>


</mapper>

好了我们来看这个配置文件仔细看会发现我们的id名就是接口中方法的名字,还有namespace是接口的全限定类名带包名,这样我们去调用 mapper.getin()的时候它就会精准的去找到我们的配置文件里面的sql语句。

其他知识点:我们写配置文件的时候resultType=""这个里面要写我们查出来的对象类型,大部分情况下我们要把全限定类名写在上面,但我们可以在Mybatis核心配置文件里面加入这个代码

XML 复制代码
 <typeAliases>
            <!-- 单个类定义别名 -->
            <typeAlias type="org.example.Cat" alias="Cat" />
     
 </typeAliases>

注意:这个配置文件要写要写在 <properties resource/>和<settings>这两个标签后面,很多人因为这个找不到问题在哪里。这样我们在写这个resultType=""的时候就可以直接写类名,还有一种办法就是用扫描的方法

XML 复制代码
 <typeAliases>
            <!-- 或批量扫描包,自动将包下所有类的类名(首字母小写)作为别名 -->
            <package name="org.example" />
        </typeAliases>

通过添加这个标签,同样要求在 <properties resource/>和<settings>这两个标签后面,但我们需要在Cat类上写一个注解

复制代码
@Alias("Cat")设置名字。

sql语句注意我们数据库里面的列名和类属性名字不一样可以用as进行修改、

XML 复制代码
<select id="getin" resultType="Cat">
        select id, car_num as num, brand, guide_price as price, produce_time as date, car_type as type from t_cat where id = #{c}
    </select>

还有一个办法就是驼峰命名

相关推荐
J_liaty1 小时前
23种设计模式一代理模式
设计模式·代理模式
独断万古他化8 小时前
【SSM开发实战:博客系统】(三)核心业务功能开发与安全加密实现
spring boot·spring·mybatis·博客系统·加密
fengxin_rou12 小时前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿
java·redis·缓存·mybatis·idea·多线程
老毛肚1 天前
MyBatis插件原理及Spring集成
java·spring·mybatis
马尔代夫哈哈哈1 天前
MyBatis 入门与实战:从配置到CRUD一站式指南
mybatis
Jul1en_1 天前
【MyBatis/plus】核心配置、插件与 MyBatis-Plus 构造器 Wrapper
mybatis
LiZhen7981 天前
SpringBoot 实现动态切换数据源
java·spring boot·mybatis
我是Superman丶1 天前
在 PostgreSQL 中使用 JSONB 类型并结合 MyBatis-Plus 实现自动注入,主要有以下几种方案
数据库·postgresql·mybatis
Pluto_CSND1 天前
基于mybatis-generator插件生成指定数据表的实体类、xml文件和dao层接口
mybatis
indexsunny1 天前
互联网大厂Java面试实战:微服务与Spring生态技术解析
java·spring boot·redis·kafka·mybatis·hibernate·microservices