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

本文探讨了MyBatis中typeHandler、jdbcType与javaType的正确使用方法,特别是它们在XML配置文件不同位置的应用差异。文章通过实例对比了属性标签内与SQL占位符内的引号使用规则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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的属性值加引号。

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值