手把手教你写一个java的orm(二)
创建映射关系
想要实现一个orm的功能,我觉得就是要将class和数据库中的表创建映射关系。把class的名称和表的名称,class属性名称和表的字段名称,属性类型与表的字段类型一一对应起来。可以通过配置文件,注解等等各种方式实现这个映射关系。
需要的依赖
因为编写配置文件总是一件十分繁琐的事情,所以我决定使用注解的方式来实现这个映射。在项目刚开始写的时候我用的是自定义注解的方法。自己规定一套注解,后来觉得这样没有太大的必要,因为已经有jpa里的一套注解。所以直接用就好了。所以添加依赖:
<dependency> <groupid>javax.persistence</groupid> <artifactid>persistence-api</artifactid> <version>1.0</version> </dependency>
这里主要使用里面的三个注解:
-
@id
添加在作为id 的字段上,标示为一个id,一个表中只能有一个id。
-
@column
添加在作为属性的字段上,name里填写表中的字段名称。
-
@table
添加在作为属性的字段上,name里填写表的名称。
其他的一些注解暂时不需要,因为我不需要完整的实现jpa里面功能。
这样就可以将一个class和一个表映射起来了。完成之后一个class大致上是这样的:
sql:
create table `user` ( `id` int(11) not null auto_increment comment '用户id', `name` varchar(225) default null comment '用户名', `create_date` datetime default null, `status` int(11) default null, `age` int(11) default null comment '年龄', `mark` varchar(225) default null, primary key (`id`) ) engine=innodb auto_increment=2104778081 default charset=latin1 comment='用户表'
class:
import java.util.date; import javax.persistence.table; import javax.persistence.column; import javax.persistence.id; /** * 用户表 * * @author hejiaxuan */ @table(name = "user") public class user { /** * 用户名 */ @column(name = "name") private string name; /** * 用户id */ @id @column(name = "id") private int id; /** * 年龄 */ @column(name = "age") private int age; /** * mark */ @column(name = "mark") private string mark; /** * create_date */ @column(name = "create_date") private date createdate; /** * status */ @column(name = "status") private int status; getter and setter and tostring }
数据类型
上面在将各种名称做了映射之后,还要根据java中的数据类型和sql中的数据类型添加一下映射关系,因为class中的数据类型和sql中的并不通用。
这个东西简单做的话其实不需要开发,在jdbc的resultset类中提供了一系列的方法:
string resultset.getstring; boolean resultset.getboolean; byte resultset.getbyte; short resultset.getshort; int resultset.getint; long resultset.getlong; float resultset.getfloat; double resultset.getdouble; bigdecimal resultset.getbigdecimal; bytes resultset.getbytes; date resultset.getdate; time resultset.gettime;
这里可以根据class的属性类型来分别的调用,也可以直接调用:object resultset.getobject;这个方法,让数据进行强制类型转换。但是这里有一定的规则,有些类型并不能转换成功,下面是我在写的时候遇到的可以转换成功的数据关系:
sql数据类型 | java数据类型 |
---|---|
varchar | string.class |
char | string.class |
text | string.class |
mediumtext | string.class |
longtext | string.class |
tinytext | string.class |
bit | boolean.class |
int | int.class |
bigint | long.class |
double | double.class |
tinyint | int.class |
float | float.class |
decimal | bigdecimal.class |
int | int.class |
bigint | int.class |
decimal | bigdecimal.class |
datetime | date.class |
time | date.class |
date | date.class |
timestamp | date.class |
按照这种关系创建class后,一般是不会碰到什么很奇怪的错误的:-d
如果想做的复杂一点,可以做一个数据类型转换的工具,可以随心所欲的转换各种数据类型。但是这里就不做了,其实也很简单的,稍微想一想就能写出来啦~~~。
这里,class和表的映射就已经结束了,已经满足了我对一个orm的需要,下一步就是要通过反射分析class并生成sql了~
我下一篇再写~~~
下一篇: pl/sql基础