MyBatis中JdbcType问题

来源:互联网 发布:excel每隔n列取数据 编辑:程序博客网 时间:2024/05/02 06:58
写Demo的时候遇到一个问题,用的oracle的emp表,comm为奖金列,可以为空,对员工的添加的时候总是报错,报莫名奇妙的错误,后来查了mybatis文档之后才知道,当Null被当作值来传递的时候,配置jdbcType是必须的,也就是说,如果确定那个列属性值可以为空,那么必须在参数后面配置好jdbcType,否则就报错,sql代码
insert into Emp(empno,ename,job,mgr,hiredate,sal,comm,deptno)values(#{empNo,JDBCTYPE=INTEGER},#{empName,jdbcType=VARCHAR2},#{job,jdbcType=VARCHAR2},#{mgr ,jdbcType=INTEGER},#{hireDate,jdbcType=NUMERIC},#{sal,jdbcType=NUMERIC},#{comm,jdbcType=NUMERIC},#{deptNo})
虽说不是必须的,但是写sql的时候建议写上jdbcType,这样可以减少错误的发生,免得半天找不到错误在哪里
原创粉丝点击