Querydsl解决Hibernate类型安全性痛点

作为最广泛使用的Java ORM框架之一,Hibernate(以及密切相关的JPA标准)提出了一种与SQL非常相似的基于字符串的查询语言HQL(JPQL)。这种方法的明显缺点是缺乏类型安全性和缺少静态查询检查。
意思是在正常情况下我们在Hibernate写sql如下:

Query q = em.createNativeQuery("SELECT a.firstname, a.lastname FROM Author a where a.firstname='David' ");

因为sql脚本在双引号中,当字段名或者类型改变了,编译过程是不知道的,直到运行时崩溃,才能发现字段名改变了或者类型改变了。 在开发阶段,数据库字段改变是常有的事情。Querydsl就是为了解决安全检查缺失。

引入Querydsl后,不用写sql语句了,而是一段一段拼接起来的java代码,相同的sql语句转化的java代码如下:

        QAuthor author = QAuthor.author;
        JPAQueryFactory queryFactory = new JPAQueryFactory( entityManager );
        Author c = queryFactory.select(author.firstname,author.lastname).from(author )
                       .where(author.firstname.eq("David"))
                       .fetchOne();

这时候如果字段有任何改动,程序编译不通过的,完美解决痛点。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容