JDBC类型

1.JDBC类型

1.1简介

  • 数据库列字段都是有类型的,不同的数据库有不同的类型。

     为了表示这些数据类型,Java源码是采用枚举来定义的:
    
public enum JDBCType implements SQLType {
    BIT(Types.BIT),
    TINYINT(Types.TINYINT),
    SMALLINT(Types.SMALLINT),
    INTEGER(Types.INTEGER)
    //省略    
}
  • 上述枚举变量的值的定义是通过types来描述刻画的:
public class Types {
    public final static int BIT             =  -7;
    public final static int TINYINT         =  -6;
    public final static int SMALLINT        =   5;
    public final static int INTEGER         =   4;
    //省略 
}
  • MyBatis包括的数据类型:
BIT、FLOAT、CHAR 、TIMESTAMP 、 OTHER 、UNDEFINEDTINYINT 、REAL 、VARCHAR 、BINARY 、BLOB NVARCHAR、SMALLINT 、DOUBLE 、LONGVARCHAR 、VARBINARY 、CLOB、NCHAR、INTEGER、 NUMERIC、DATE 、LONGVARBINARY 、BOOLEAN 、NCLOB、BIGINT 、DECIMAL 、TIME 、NULL、CURSOR

1.2对应关系

JdbcType和Java类型的对应关系如下:(注:不同数据库可能有细微的区别)

JDBC Type           Java Type  
CHAR                String  
VARCHAR             String  
LONGVARCHAR         String  
NUMERIC             java.math.BigDecimal  
DECIMAL             java.math.BigDecimal  
BIT                 boolean  
BOOLEAN             boolean  
TINYINT             byte  
SMALLINT            short  
INTEGER             INTEGER  
BIGINT              long  
REAL                float  
FLOAT               double  
DOUBLE              double  
BINARY              byte[]  
VARBINARY           byte[]  
LONGVARBINARY       byte[]  
DATE                java.sql.Date  
TIME                java.sql.Time  
TIMESTAMP           java.sql.Timestamp  
CLOB                Clob  
BLOB                Blob  
ARRAY               Array  
DISTINCT            mapping of underlying type  
STRUCT              Struct  
REF                 Ref  
DATALINK            java.net.URL

1.3作用

  • 在Mybatis中,用INSERT语句插入数据时,最好将JdbcType加上。

  • 原因:如果某个字段为空,mybatis在通过INSERT语句插入时,不知道具体转换成什么jdbcType类型,通常

    会使用一个默认设置。虽然这样做一般情况下不会出错,但是个别情况还是会有问题的。

    Mybatis经常出现的:无效的列类型: 1111 错误,就是因为没有设置JdbcType造成的。

你可能感兴趣的:(JDBC类型)