开发者社区> 云栖号资讯小哥> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

最受欢迎Java数据库访问框架(DAO层)

简介: 本文将带您浏览和比较最受欢迎Java数据库访问框架(DAO层)。假设您正在开发一个Java程序,有许多办法可以让您的应用连上数据库。下面会列举各数据库访问框架的适用场景,相信能够帮您选到适合项目的开发框架。
+关注继续查看

云栖号资讯:【点击查看更多行业资讯
在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来!

本文将带您浏览和比较最受欢迎Java数据库访问框架(DAO层)。
假设您正在开发一个Java程序,有许多办法可以让您的应用连上数据库。下面会列举各数据库访问框架的适用场景,相信能够帮您选到适合项目的开发框架。

JDBC:简单数据库查询

最简单的办法莫过于使用JDBC提供的Java API。输入查询SQL语句调用API返回结果:

ResultSet rs = stmt.executeQuery("SELECT id, name FROM Employees");
while(rs.hasNext()){
 log.info("Employee id: " + rs.getInt("id") + " has name: " + rs.getString("name"));
}

适用场景:不希望学新框架,要求轻量级解决方案,需自定义查询,不用长期维护;

不适合:不想写很多代码,未来可能需要做数据库迁移。

要减少模板代码,可以考虑使用jdbc-template工具,像是Spring JDBC template或者Apache DBUtils。例如在处理request时,Spring template可以用一句代码发送带参数的request,完成反序列化数据,关闭连接:

User user = jdbc.qeuryForObject("SELECT * FROM USERS WHERE ID = ?", 1, User.class);

JOOQ:面Java对象查询

JOOQ提供了一种DSL来解决查询问题。这种语言基于生成的entity对象提供编译时安全(compile-time-safe)查询。JOOQ支持不同的数据库,能够减少模板代码。

UserRecord user = new UserRecord();
user.setId(1);
user.setName("Peter");

Result<UserRecord> books1 = DSL.using(configuration)
   .selectFrom(USERS)
   .where(condition(user))
   .fetch();

适用场景:要求JDBC查询保证编译时安全,迁移到不同数据库,自动生成CRUD JDBC API;

不适合:一些高级功能要收费。

MyBatis:带查询功能的简单ORM

ORM(对象关系映射)提供了另一种和数据库打交道的方式,其核心思想是把Java对象(entity)映射到对应的数据库表。MyBatis就是其中一员。

MyBatis是一个轻量级框架,使用JPA provider(非bean结构)完成映射。下面是一个简单的示例查询(不用配置文件):

// Bean映射
public interface BlogMapper {
 3
  @Select("SELECT * FROM blog WHERE id = #{id}")
  Blog selectBlog(int id);
}

// 获取数据
BlogMapper mapper = session.getMapper(BlogMapper.class);
Blog blog = mapper.selectBlog(101);

适用场景:需要在ORM中灵活地查询,轻量级ORM;

不适合:不喜欢XML。

Hibernate与Spring Data

二者都支持JPA(Java持久化API),也就是说都支持部署到应用服务器。JPA标准中要求数据库table/column与Java对象(entity)对应。例如,USER表对应的entity如下:

@Data // 这不是hibernate注解,而是lombok getter/setter
@Entity
@Table(name = "USERS")
public class User {
    @Id
    @Column(name = "id")
    private Integer id;
    @Column(name = "name")
    private String name;
}

Hibernate是最受欢迎的ORM框架,提供很多开箱即用的功能。早在2001年Hibernate就发布了第一个版本。还支持HQL语言进行自定义SQL查询。

Session session = sessionFactory.openSession();
User oldUser  = (User) session.get(User.class, 1); //get user
User newUser = new User(123,"John");
session.save(developer); //add user

//HQL 示例
Query query = session.createQuery("FROM Users");
List users = query.list();

适用场景:快速原型,需要内部提供缓存,使用多种不同的数据库,访问复杂schema;

不适合:不喜欢生成其他Java实体类,不愿意学习新框架,需要掌控底层细节。

Spring Data:新ORM抽象层

Spring Data在JPA entity的基础上提供了丰富的CRUD API以及查询表达式语言。其最大的优势在于只需要2-3行代码可以搞定。生成的API基于函数命名规范。

// 只需要实现CrudRepository interface
public interface UserRepository extends CrudRepository<User, Long> {
  User findByName(String name);
  User findById(long id);
  @Query("SELECT u.ID FROM USERS u WHERE like ?1") //自定义表达式
  List<Integer> findByUserName(String name);
}

// 查询示例
User johnUser = userRepository.findByName("John");
User johnUser = userRepository.findById(id);
List<Integer> usersIdsWithOVPostfix = userRepository.findByUserName("%OV%");

总结

下面这张表进行了总结。注意:仅代表作者个人观点,没有做严谨的分析与测试。

9F7B5196_7DF3_41e1_B319_418398D172B0

【云栖号在线课堂】每天都有产品技术专家分享!
课程地址:https://yqh.aliyun.com/zhibo

立即加入社群,与专家面对面,及时了解课程最新动态!
【云栖号在线课堂 社群】https://c.tb.cn/F3.Z8gvnK

原文发布时间:2020-06-03
本文作者: 覃佑桦
本文来自:“互联网架构师 微信公众号”,了解相关信息可以关注“互联网架构师

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

相关文章
珠联壁合地设天造|M1 Mac os(Apple Silicon)基于vscode(arm64)配置搭建Java开发环境(集成web框架Springboot)
也许有人从未听说过Python,但是不会有人没听说过Java,它作为一个拥有悠久历史的老牌编程语言,常年雄踞TIOBE编程语言榜首,其顶尖的霸主地位不可撼动,而M1 mac业已发布了一段时间,作为跨时代的顶级芯片系统,这两大巨头能否珠联璧合,让开发者们猛虎添翼、更上层楼?本次我们尝试在M1 mac系统中搭建Java开发环境,并且集成目前Web开发领域红的发紫的Springboot框架,另外,谁说玩儿Java就必须得用Eclipse或者IntelliJ IDEA?我们就骄傲地使用Vscode。
0 0
Java开发 - Mybatis框架初体验
在前文中,我们已经学习了Spring框架,Spring MVC框架,相信大家对这些基础的内容已经熟练使用了,今天,我们继续来学习Mybatis框架。就目前而言,Mybatis框架依然是比较实用的框架,这篇博客,将通过Mybatis框架和Spring框架的结合,来讲解Mybatis框架的使用,学完之后你就可以自己写接口玩了。
0 0
【Java技术指南】「并发编程专题」Fork/Join框架基本使用和原理探究(原理篇)
【Java技术指南】「并发编程专题」Fork/Join框架基本使用和原理探究(原理篇)
0 0
【Java技术指南】「并发编程专题」CompletionService框架基本使用和原理探究(基础篇)
【Java技术指南】「并发编程专题」CompletionService框架基本使用和原理探究(基础篇)
0 0
【Java技术指南】「并发编程专题」Fork/Join框架基本使用和原理探究(基础篇)
【Java技术指南】「并发编程专题」Fork/Join框架基本使用和原理探究(基础篇)
0 0
【Java技术指南】「TestNG专题」单元测试框架之TestNG使用教程指南(下)
【Java技术指南】「TestNG专题」单元测试框架之TestNG使用教程指南(下)
0 0
【Java技术指南】「TestNG专题」单元测试框架之TestNG使用教程指南(上)
【Java技术指南】「TestNG专题」单元测试框架之TestNG使用教程指南(上)
0 0
Java开发 - Spring MVC框架初体验(四)
Java开发 - Spring MVC框架初体验
0 0
Java开发 - Spring MVC框架初体验(三)
Java开发 - Spring MVC框架初体验
0 0
Java开发 - Spring MVC框架初体验(二)
Java开发 - Spring MVC框架初体验
0 0
+关注
云栖号资讯小哥
云栖号小编在此 ^o^
文章
问答
文章排行榜
最热
最新
相关电子书
更多
JAVA 应用排查全景图
立即下载
Java工程师必读手册
立即下载
Java应用提速(速度与激情)
立即下载