不同的是它们包含二进制字符串而不要非二进制字符串,mysql数据类型与java数据类型对照表

发布时间:2019-11-24  栏目:数据  评论:0 Comments

本文讲述了Java数据类型与MySql数据类型对照表。分享给大家供大家参考,具体如下:

Jdbc的核心api:

MyBatis 通过包含的jdbcType类型 BIT FLOAT CHAR TIMESTAMP OTHER UNDEFINED
TINYINT REAL VARCHAR BINARY BLOB NVARCHAR SMALLINT DOUBLE LONGVARCHAR
VARBINARY CLOB NCHAR INTEGER NUMERIC DATE LONGVARBINARY BOOLEAN NCLOB
BIGINT DECIMAL TIME NULL CURSOR
Mybatis中javaType和jdbcType对应和CRUD例子
Mybatis中javaType和jdbcType对应关系 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 int 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[color=red][/color]

MySQL 数据类型

MySQL中定义数据字段的类型对你数据库的优化是非常重要的。

在 MySQL 中,有三种主要的类型:文本、数字和日期/时间类型。

数值型:

类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引
VARCHAR L+N VARCHAR java.lang.String 12 CHAR
N CHAR java.lang.String 1 BLOB L+N BLOB
java.lang.byte[] -4 TEXT 65535 VARCHAR
java.lang.String -1 INTEGER 4 INTEGER UNSIGNED
java.lang.Long 4 TINYINT 3 TINYINT UNSIGNED
java.lang.Integer -6 SMALLINT 5 SMALLINT UNSIGNED
java.lang.Integer 5 MEDIUMINT 8 MEDIUMINT UNSIGNED
java.lang.Integer 4 BIT 1 BIT java.lang.Boolean
-7 BIGINT 20 BIGINT UNSIGNED java.math.BigInteger
-5 FLOAT 4+8 FLOAT java.lang.Float 7 DOUBLE
22 DOUBLE java.lang.Double 8 DECIMAL 11
DECIMAL java.math.BigDecimal 3 BOOLEAN 1
同TINYINT ID 11 PK java.lang.Long 4 DATE
10 DATE java.sql.Date 91 TIME 8 TIME
java.sql.Time 92 DATETIME 19 DATETIME
java.sql.Timestamp 93 TIMESTAMP 19 TIMESTAMP
java.sql.Timestamp 93 YEAR 4 YEAR java.sql.Date
91

        |-Driver接口: 驱动程序接口。
            |-Connection connect()   用于连接数据库的方法
                可以使用驱动程序管理类获取连接:
                        DriverManager.getConnection(url,user,pasword);

        |-Connection接口: 代表和数据库的连接
            |- Statement createStatement()  创建Statement接口的对象。
            |- PreparedStatement prepareStatement(String sql)  创建PreparedStatement接口的对象。
            |- CallableStatement prepareCall(String sql)创建CallableStatement接口的对象。

        |-Statement接口:用于执行静态 SQL 语句。
            |- int executeUpdate(String sql)  执行DDL和DML语句(更新sql语句)
            |- ResultSet executeQuery(String sql)  执行DQL语句(查询sql语句)

            |-PreparedStatement接口:用于执行预编译的 SQL 语句
                |- int executeUpdate():执行DDL和DML语句(更新sql语句)
                |- ResultSet executeQuery() 执行DQL语句(查询sql语句)

                |-CallableStatement接口: 用于执行存储过程的SQL语句
                    |- ResultSet executeQuery() 存储过程只能执行查询sql  

        |-ResultSet接口: 表示数据库结果集。
             |- boolean next()   将光标移至下一行
             |- getXXX(): 获取结果集中的每列的值

Text 类型:

字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。该节描述了这些类型如何工作以及如何在查询中使用这些类型。

CHAR和VARCHAR类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。

BINARY和VARBINARY类类似于CHAR和VARCHAR,不同的是它们包含二进制字符串而不要非二进制字符串。也就是说,它们包含字节字符串而不是字符字符串。这说明它们没有字符集,并且排序和比较基于列值字节的数值值。

BLOB是一个二进制大对象,可以容纳可变数量的数据。有4种BLOB类型:TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB。它们只是可容纳值的最大长度不同。

有4种TEXT类型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT。这些对应4种BLOB类型,有相同的最大长度和存储需求。

数据类型 描述
CHAR(size) 保存固定长度的字符串(可包含字母、数字以及特殊字符)。在括号中指定字符串的长度。最多 255 个字符。
VARCHAR(size)

保存可变长度的字符串(可包含字母、数字以及特殊字符)。在括号中指定字符串的最大长度。最多 255 个字符。

注释:如果值的长度大于 255,则被转换为 TEXT 类型。

TINYTEXT 存放最大长度为 255 个字符的字符串。
TEXT 存放最大长度为 65,535 个字符的字符串。
BLOB 用于 BLOBs (Binary Large OBjects)。存放最多 65,535 字节的数据。
MEDIUMTEXT 存放最大长度为 16,777,215 个字符的字符串。
MEDIUMBLOB 用于 BLOBs (Binary Large OBjects)。存放最多 16,777,215 字节的数据。
LONGTEXT 存放最大长度为 4,294,967,295 个字符的字符串。
LONGBLOB 用于 BLOBs (Binary Large OBjects)。存放最多 4,294,967,295 字节的数据。
ENUM(x,y,z,etc.)

允许你输入可能值的列表。可以在 ENUM 列表中列出最大 65535 个值。如果列表中不存在插入的值,则插入空值。

注释:这些值是按照你输入的顺序存储的。

可以按照此格式输入可能的值:ENUM(‘X’,’Y’,’Z’)

SET 与 ENUM 类似,SET 最多只能包含 64 个列表项,不过 SET 可存储一个以上的值。

1.整数类型:

对于bolb,一般用于对图片的数据库存储,原理是把图片打成二进制,然后进行的一种存储方式,在java中对应byte[]数组。

jdbc操作步骤:

Number 类型:

MySQL支持所有标准SQL数值数据类型。

这些类型包括严格数值数据类型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似数值数据类型(FLOAT、REAL和DOUBLE
PRECISION)。

关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。

BIT数据类型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。

作为SQL标准的扩展,MySQL也支持整数类型TINYINT、MEDIUMINT和BIGINT。下面的表显示了需要的每个整数类型的存储和范围。

数据类型 描述
TINYINT(size) -128 到 127 常规。0 到 255 无符号*。在括号中规定最大位数。
SMALLINT(size) -32768 到 32767 常规。0 到 65535 无符号*。在括号中规定最大位数。
MEDIUMINT(size) -8388608 到 8388607 普通。0 to 16777215 无符号*。在括号中规定最大位数。
INT(size) -2147483648 到 2147483647 常规。0 到 4294967295 无符号*。在括号中规定最大位数。
BIGINT(size) -9223372036854775808 到 9223372036854775807 常规。0 到 18446744073709551615 无符号*。在括号中规定最大位数。
FLOAT(size,d) 带有浮动小数点的小数字。在括号中规定最大位数。在 d 参数中规定小数点右侧的最大位数。
DOUBLE(size,d) 带有浮动小数点的大数字。在括号中规定最大位数。在 d 参数中规定小数点右侧的最大位数。
DECIMAL(size,d) 作为字符串存储的 DOUBLE 类型,允许固定的小数点。

* 这些整数类型拥有额外的选项
UNSIGNED。通常,整数可以是负数或正数。如果添加 UNSIGNED
属性,那么范围将从 0 开始,而不是某个负数。

    1.1.TINYINT

对于boolen类型,在mysql数据库中,个人认为用int类型代替较好,对bit操作不是很方便,尤其是在具有web页面开发的项目中,表示0/1,对应java类型的Integer较好。

            1)注册驱动程序
            2)获取连接对象
            3)准备sql语句(DDL+DML)
            4)创建Statement对象( Statement,PreparedStatment,CallableStement  )
            5)执行sql语句
                 DDL+DML: executeUpdte(sql)
                DQL; executeQuery()
            6)返回结果,处理结果
                ResultSet
            7)关闭资源

Date 类型:

表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。

每个时间类型有一个有效值范围和一个”零”值,当指定不合法的MySQL不能表示的值时使用”零”值。

TIMESTAMP类型有专有的自动更新特性,将在后面描述。

数据类型 描述
DATE()

日期。格式:YYYY-MM-DD

注释:支持的范围是从 ‘1000-01-01’ 到 ‘9999-12-31’

DATETIME()

*日期和时间的组合。格式:YYYY-MM-DD HH:MM:SS

注释:支持的范围是从 ‘1000-01-01 00:00:00’ 到 ‘9999-12-31 23:59:59’

TIMESTAMP()

*时间戳。TIMESTAMP 值使用 Unix 纪元(‘1970-01-01 00:00:00’ UTC) 至今的描述来存储。格式:YYYY-MM-DD HH:MM:SS

注释:支持的范围是从 ‘1970-01-01 00:00:01’ UTC 到 ‘2038-01-09 03:14:07’ UTC

TIME() 时间。格式:HH:MM:SS注释:支持的范围是从 ‘-838:59:59’ 到 ‘838:59:59’
YEAR()

2 位或 4 位格式的年。

注释:4 位格式所允许的值:1901 到 2155。2 位格式所允许的值:70 到 69,表示从 1970 到 2069。

* 即便 DATETIME 和 TIMESTAMP 返回相同的格式,它们的工作方式很不同。在
INSERT 或 UPDATE 查询中,TIMESTAMP
自动把自身设置为当前的日期和时间。TIMESTAMP 也接受不同的格式,比如
YYYYMMDDHHMMSS、YYMMDDHHMMSS、YYYYMMDD 或 YYMMDD。

    1.2.SMALLINT

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

JdbcUtil:

    1.3.MEDIUMINT

希望本文所述对大家MySQL数据库计有所帮助。

public class JdbcUtil {

    private static Properties config = new Properties();

    // 1.注册驱动
    static {
        try {
            JdbcUtil.class.getClassLoader();
            config.load(Thread.currentThread().getContextClassLoader().getResourceAsStream("database.properties"));
            //config.load(JdbcUtil.class.getClassLoader().getSystemResourceAsStream("database.properties"));
            //config.load(ClassLoader.getSystemResourceAsStream("database.properties"));
            Class.forName(config.getProperty("driver"));
        } catch (IOException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }

    // 2.获得链接对象
    public static Connection getConnection() throws SQLException {
        return DriverManager.getConnection(config.getProperty("url"), config.getProperty("user"), config.getProperty("password"));
    }

    // 6.释放资源
    public static void release(Connection connection, Statement statement){

        if (statement != null) {
            try {
                statement.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
            statement = null;
        }

        if (connection != null) {
            try {
                connection.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }


    public static void release(Connection connection, Statement statement, ResultSet resultSet){

        if (resultSet != null) {
            try {
                resultSet.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
            resultSet = null;
        }

        release(connection, statement);
    }
}

    1.4.INT

statement操作:

    1.5.INTEGER

相关文章

留下评论

网站地图xml地图