51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 1941|回复: 2
打印 上一主题 下一主题

手把手教你写一个java的orm(二)

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2019-2-1 16:18:42 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创建映射关系
​ 想要实现一个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数据类型
VARCHARString.class
CHARString.class
TEXTString.class
MEDIUMTEXTString.class
LONGTEXTString.class
TINYTEXTString.class
BITBoolean.class
INTint.class
BIGINTlong.class
DOUBLEdouble.class
TINYINTint.class
FLOATfloat.class
DECIMALBigDecimal.class
INTint.class
BIGINTint.class
DECIMALBigDecimal.class
DATETIMEDate.class
TIMEDate.class
DATEDate.class
TIMESTAMPDate.class
按照这种关系创建class后,一般是不会碰到什么很奇怪的错误的:-D
​ 如果想做的复杂一点,可以做一个数据类型转换的工具,可以随心所欲的转换各种数据类型。但是这里就不做了,其实也很简单的,稍微想一想就能写出来啦~~~。
这里,class和表的映射就已经结束了,已经满足了我对一个orm的需要,下一步就是要通过反射分析class并生成sql了~
我下一篇再写~~~
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-4-25 09:43 , Processed in 0.070034 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表