mysql与JFinal的数据关系-阿里云开发者社区

开发者社区> 沉默王二> 正文

mysql与JFinal的数据关系

简介: mysql与JFinal的数据关系
+关注继续查看

mysql与jfinal在使用过程中,一定要弄清楚数据关系,否则容易发生类型不匹配的错误。


一、关系整理


为此,我根据jfinal的源码和mysql的数据字段类型,整理列表如下:


mysql jfinal 例子 编号

varchar, char, enum, set, text, tinytext, mediumtext, longtext String getStr(“xxx”) 0001

int, integer, tinyint(n) n > 1, smallint, mediumint int getInt(“xxx”) 0002

bigint, unsign int long getLong(“xxx”) 0003

unsigned bigint BigInteger getBigInteger(“xxx”) 0004

date, year Date getDate(“xxx”) 0005

time Time getTime(“xxx”) 0006

timestamp, datetime Timestamp getTimestamp(“xxx”) 0006

real, double Double getDouble(“xxx”) 0007

float Float getFloat(“xxx”) 0008

bit, tinyint(1) Boolean getBoolean(“xxx”) 0009

decimal, numeric BigDecimal getBigDecimal(“xxx”) 0010

binary, varbinary, tinyblob, blob, mediumblob, longblob byte[] getBytes(“xxx”) 0011

extends from Number Number getNumber(“xxx”) 0012

二、tinyint


在mysql中,tinyint(n)中的n对jfinal的数据转换有影响:


n>1时,jfinal要使用getInt。

n=1时,jfinal要使用getBoolean。

三、unsigned


在mysql中unsigned表示有无符号,举例来说:


unsigned int,表示数据>0,不包含负数,那么jfinal就要使用getLong。

unsigned bigint,表示数据>0,不包含负数,那么jfinal就要使用getBigInteger。

四、int(m)


关于mysql中int(m)中的m,这当然包含bigint(m)的m。


int[(m)]

有符号值:-2147683648 到2147683647(- 231 到231- 1)

无符号值:0到4294967295(0 到232 - 1) 4个字节

这意味着,如果你的数据字段是这样子的话


`uid` int(11) NOT NULL DEFAULT '0' COMMENT '用户id'


那么m=11是正确的,因为考虑到“-”(负数),长度最大为11位。


而如果你的数据字段是这样子的话


`uid` int(11) unsigned NOT NULL COMMENT '用户id'


那么m=11是没有意义的,因为最大长度为10位,如果你比较专业的话,此时,你的数据字段就应该是这样子的


`uid` int(10) unsigned NOT NULL COMMENT '用户id'


五、jfinal的api


只看如下代码:

/**
  * Get attribute of mysql type: int, integer, tinyint(n) n > 1, smallint, mediumint
  */
 public Integer getInt(String attr) {
  return (Integer)attrs.get(attr);
 }
 /**
  * Get attribute of mysql type: bigint, unsign int
  */
 public Long getLong(String attr) {
  return (Long)attrs.get(attr);
 }


方法很详细的介绍了应该匹配哪一种mysql数据类型。


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
9494 0
sqoop数据迁移(基于Hadoop和关系数据库服务器之间传送数据)
1:sqoop的概述: (1):sqoop是apache旗下一款“Hadoop和关系数据库服务器之间传送数据”的工具。(2):导入数据:MySQL,Oracle导入数据到Hadoop的HDFS、HIVE、HBASE等数据存储系统;(3):导出数据:从Hadoop的文件系统中导出数据到关系数据库...
1628 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
13177 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
11507 0
+关注
沉默王二
微信搜索「沉默王二」,回复关键字「00」获取硬核计算机基础资料。
1084
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载