...
by qx.zhong
Hangzhou 29 Jun 2014
开发环境
OS: Win8.1 x64
JDK: 1.8 SE
DB: MySQL 5.5
Lib: mysql-connector-java.jar
1. MySQL数据库数据类型与JDK之间的特殊对应关系
下表只列举几个特殊的值类型对照,其余的又需要可以参考MySQL官网的值类型说明(http://dev.mysql.com/doc/refman/5.1/zh/index.html)以及JDK的相关资料。
MySQL |
JDK |
tinyint(1) |
boolean |
int unsigined |
long |
datetime |
java.sql.Timestamp |
varchar |
String |
在MySQL中,TINYINT(1)是BOOL, BOOLEAN的同义词带符号的范围是-128到127。无符号的范围是0到255。BOOLEAN非zero为真,zero为假。
INT UNSIGINED值的范围超出了JDK的int类型(JDK中的整形类型都是带符号的)的最大取值范围,所以需要用long装载。
2. 采用JDK的反射机制将JDBC ResultSet的自动加载到Bean类
首先要确保MySQL中的列名和JavaBean类的属性名是一一对应的,然后就可以使用反射机制调用setter对Bean进行赋值,关键代码:
/** *Using reflection to storage the result from database into Bean class. * */ public static List