首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JAVA:自定义套件...

JAVA:自定义套件...

作者头像
哲洛不闹
发布2018-09-14 11:22:15
8030
发布2018-09-14 11:22:15
举报
文章被收录于专栏:java一日一条java一日一条

各位亲爱的小伙伴们大家好,最近很多伙伴都问我该怎么做自定义套件封装,我在这里做了一个教程分享给大家。

java开发人员现在对数据库的操作一般会用到诸如像Hibernate,Mybatis,SpringJdbcTemplate等ORM组件,但是这些组件是怎样从原始的编码方式一步步封装过来的呢 ?

一、最原始的编码方式

如下图所示: 我在05年刚毕业的时候,曾经是这样写Jdbc访问数据库的.

二、封装的过程和思路

总得来说,Java组件封装的原则就是高内聚,低耦合,直白一点的解释就是将重复性的代码提取出去作为工具类,尽量减少类与类之间的固定依赖。

1) DbUtil工具类

通过查看最原始编码方式的代码 ,我们可以看出,获取数据库的连接和关闭数据库连接的代码,在每一次操作中都需要,所以我们可以思考一下,将这部分代码提取出去.

* 新建DbUtil工具类 ,用于数据库的开连接和关连接

通过工具类的封装,我们可以继续在工具类里面将数据库的信息通过配置文件加载,以及启用流行的连接池技术,在这里不在赘述.

2) 增删改方法的封装

在封装了DbUtil工具类的基础上,我们试着做一个单表的增删改查,请看以下代码:

进一步观察增删改方法 ,除了Sql语句和参数传入的不同,其他代码其实也是重复的,我们是否可以考虑将这些公用的代码也提取出去呢?

伟大的Java程序员们都是”懒鬼”,一切都是为了少些一些重复的代码以提高工作效率.

我们可以新建一个模板类JdbcTemplate, 对增删改方法进行封装,外部只需要传入sql语句和sql语句需要用到的参数.

通过上面步骤的封装,我们再来看看让对单表增删改的操作是如何方便简单的,新建一个单表增删改的测试类,继承我们封装的模板类,代码如下:

回过头看看我们的封装过程和代码,是不是对于开发人员来讲 ,越来越简单,代码写的越来越少,这就是Java在实际开发过程中需要用到大量前辈们封装的组件的原因.

3) 查询方法的封装

在增删改方法的封装过程当中,我们发现,增删改的操作,方法的返回值是固定的,但是查询方法的返回值是不固定的,查询不同的表,返回的是不同对象,也有可能是返回的其他类型的值.

通过以上分析,我们封装查询方法的时候,只能返回一个固定格式的对象或者列表,让执行查询的人来解析固定格式的结果得到自己想要的返回值.

两种方式:

a:返回一个List<Map<Object,Object>结构

在JdbcTemplate模板类面新加查询模板方法

这种封装方式在执行查询时候,获取的结果是List<Map<Object,Object>>结构的值,需要自己再进行转化,但是对于查询来说,就非常的简单了。

在UserDaoTemplateTest类里面新加查询方法

b:返回一个接口的匿名内部类

这种方式,封装起来稍微复杂一些,但是对于查询方来说,就可以直接在查询方法里面获取自己想要的对象,返回List<Bean>,

非常简单。

步骤:

* 新建一个接口 RowMapper<T>,成员是一个匿名的内部类

* 在JdbcTemplate模板类里面新增模板查询方法

* 查询的时候,通过实现匿名的内部类来获取结果,直接映射到Java对象当中 ,如代码所示,在UserDaoTemplateTest中进行查询

最终的代码目录结构如下,希望对大家的学习有所帮助。

如果需要达到像Mybatis和Hibernate等组件的高度,还有很长的一段的路要走,有兴趣的同学可以查看一下SpringJdbcTemplate的源码,其中的思想是跟它不谋而合的。

三、总结

通过以上的封装过程,我们可以了解到Java封装组件的一个基本思路,有助于大家以后在用到相关的ORM组件时,对它们有一个更深得到认识。当然,本篇文章封装的代码只是冰山一角,还有更多精彩有料有趣内容,想要学好java的伙伴们还有更多福利哦,希望各位伙伴们不要错过这次和以后的精彩内容。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-07-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 java一日一条 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、最原始的编码方式
  • 二、封装的过程和思路
    • 1) DbUtil工具类
      • 2) 增删改方法的封装
        • 3) 查询方法的封装
        • 三、总结
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档