mybatis的XML配置文件中,typeHandler、jdbcType、javaType的使用

1.前言

typeHandler、jdbcType、javaType都是用来处理java数据类型和jdbc数据库数据类型的转换问题,但在xml的不同位置使用需要注意引号使用问题。

2.在xml的不同位置的使用方式

1)在xml的尖括号标签内做属性

      必须给属性值加引号

    <typeHandlers>
        <typeHandler handler="org.apache.ibatis.type.EnumTypeHandler"
            javaType="Sex" />
    </typeHandlers>

    如果没有引号则要报错

    2) 在xml的sql语句占位'#{   }'内

不能使用引号

后台java测试方法

复制代码
    private SqlSession sqlSession = null;
    @Before
    public void openSession()
    {
        sqlSession = MyBatisUtil.createSqlSession();
    }
    
    @Test
    public void addStudent()
    {
        int addRows = sqlSession.insert("com.kgc.dao.StudentMapper.addStudent",
            new Student(Short.valueOf("23"), Sex.FEMALE, "张大明"));
        sqlSession.commit();
        System.out.println("新增的行数" + addRows);
    }
    
复制代码

 

 

示例1:给typeHandler、jdbcType、javaType加上引号

复制代码
    <insert id="addStudent" parameterType="Student"
        useGeneratedKeys="true" keyProperty="id">
        <selectKey keyProperty="id" resultType="string" order="BEFORE">
            select uuid()
        </selectKey>
        insert into test_student (id,age, sex, name)
        values (#{id},
        #{age ,jdbcType="TINYINT" ,javaType="short"},
        #{sex, typeHandler="org.apache.ibatis.type.EnumTypeHandler"},
        #{name} )
    </insert>
复制代码

 

 JUinit提示不知道"TINYINT"的枚举类型

 

 

示例2:取消typeHandler、jdbcType、javaType属性值的引号

复制代码
    <insert id="addStudent" parameterType="Student"
        useGeneratedKeys="true" keyProperty="id">
        <selectKey keyProperty="id" resultType="string" order="BEFORE">
            select uuid()
        </selectKey>
        insert into test_student (id,age, sex, name)
        values (#{id},
        #{age ,jdbcType=TINYINT ,javaType=short},
        #{sex, typeHandler=org.apache.ibatis.type.EnumTypeHandler},
        #{name} )
    </insert>
复制代码

 控制台打印,增加数据成功。

3.总结

在xml的尖括号标签内做属性,需要给typeHandler、jdbcType、javaType的属性值加引号;

 在xml的sql语句占位'#{   }'内 ,不能给typeHandler、jdbcType、javaType的属性值加引号。

 


作者:蜀中孤鹰
个性签名:技术如逆水行舟,不进则退;若持之以恒,则水滴穿石。

             IT新手,水平有限,谬误疏漏之处,敬请谅解哦! 

posted @   蜀中孤鹰  阅读(1496)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
阅读排行:
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 推荐几款开源且免费的 .NET MAUI 组件库
· 实操Deepseek接入个人知识库
· 易语言 —— 开山篇
· Trae初体验
点击右上角即可分享
微信分享提示