【ArchSummit】如何通过AIOps推动可量化的业务价值增长和效率提升?>>> 了解详情
写点什么

为 Cloud Spanner 引入 Hibernate ORM 以便使用数据库

  • 2020-05-26
  • 本文字数:2695 字

    阅读完需:约 9 分钟

为 Cloud Spanner 引入 Hibernate ORM 以便使用数据库

当您采用新的数据库技术时,如何学习新的 SQL 方言或编写新的数据持久层逻辑,都是需要考虑的事项。我们希望尽可能简化这一流程。对于此类工作,Hibernate 实际上已成为 Java 项目的标准对象关系映射 (ORM) 解决方案。Hibernate 支持所有主要关系型数据库,并支持 Spring Data JPA 等功能更为强大的 ORM 工具。


我们已开发出全新开源 Cloud Spanner Dialect for Hibernate ORM,让用户能够更加轻松地采用 Cloud Spanner。现在,您可以通过 Hibernate 所习惯使用的数据持久层处理获得 Cloud Spanner 的优势:即可扩展性和关系数据库语义。这样一来,您可以将现有应用程序迁移到云中,或使用 Hibernate 兼容环境的常用 API(例如 JPA、Spring Data JPA、Microprofile 和 Quarkus)编写新的应用。


Hibernate ORM 提供以下两大主要优势,可帮助解决采用新数据库技术时面临的挑战:跨数据库的可移植性,以及创建-读取-更新-删除 (CRUD) 逻辑的易编写性。借助这些优势,开发者的工作效率得以提高,云数据库的采用速度也得到提升。


如需了解详细信息,请查看我们的文档、git 代码库,或试用 Codelab。

如何使用 Hibernate 和 Cloud Spanner 编写 Java 应用

接下来,我们将为您简要介绍如何编写使用 Hibernate 访问 Cloud Spanner 的 Java 应用。具体步骤与您在 Codelab 中看到的类似。我们将创建一个应用,将音乐人及其专辑存储在 Cloud Spanner 中。虽然这只是一个基本的 Hibernate 示例,但请记住,此方法也适用于由 Hibernate 提供支持的 JPA 型系统。


我们需要适用于 Hibernate 的 Cloud Spanner 方言,开源 Cloud Spanner JDBC 驱动程序,以及 Hibernate 核心。我们先将这些依赖项添加至应用。


pom.xml


 <dependencies>
复制代码


<dependency>  <groupId>com.google.cloud</groupId>  <artifactId>google-cloud-spanner-hibernate-dialect</artifactId>
复制代码


  <version>1.0.0</version>
复制代码


</dependency>
<!-- JDBC Driver --><dependency> <groupId>com.google.cloud</groupId> <artifactId>google-cloud-spanner-jdbc</artifactId> <version>1.11.0</version>
复制代码


  </dependency>
复制代码


<!-- Hibernate --><dependency>  <groupId>org.hibernate</groupId>  <artifactId>hibernate-core</artifactId>  <version>5.4.9.Final</version></dependency>
复制代码


src/main/resources/hibernate.cfg.xml


<hibernate-configuration>
复制代码


Hibernate 也需要知道如何连接到 Cloud Spanner 实例以及使用哪种方言。于是,我们指示 Hibernate 使用适合 SQL 语法的 SpannerDialect、Cloud Spanner JDBC 驱动程序,以及带有数据库坐标的 JDBC 连接字符串。


src/main/resources/hibernate.properties


hibernate.dialect=com.google.cloud.spanner.hibernate.SpannerDialect
hibernate.connection.driver_class=com.google.cloud.spanner.jdbc.JdbcDriver
hibernate.connection.url=jdbc:cloudspanner:/projects/{INSERT_PROJECT_ID}/instances/{INSERT_INSTANCE_ID}/databases/{INSERT_DATABASE_ID}
# auto-create and update DB schemahibernate.hbm2ddl.auto=update
复制代码


我们将使用 GOOGLE_APPLICATION_CREDENTIALS 环境变量中的服务帐号 JSON 文件,或使用通过“gcloud auth application-default login”命令配置的应用默认凭据来确保完成身份验证凭据设置。


现在我们准备就绪,可以编写一些代码。


我们将定义两个普通的旧 Java 对象 (POJO),其将映射到 Cloud Spanner 中的两个表格(Singer 和 Album)。Album 将与 Singer 建立 @ManyToOne 关系。我们也可以将 Singers 映射到带有 @OneToMany 注解的 Albums 列表,但在此示例中,我们不希望每次需要从数据库中获取歌手时都加载所有专辑。


由于没有现成的数据库架构,我们添加了 hibernate.hbm2ddl.auto=update 属性,以便让 Hibernate 于首次运行应用时在 Cloud Spanner 中创建两个表格。


src/main/java/demo/Application.java


 @Entityclass Singer {  @Id  @GeneratedValue
复制代码


@Type(type = “uuid-char”)


  UUID singerId;
String firstName;
String lastName;
复制代码


@Temporal(TemporalType.DATE)


  Date birthDate;}
复制代码


@Entity


class Album {


@Id


@GeneratedValue


@Type(type = “uuid-char”)


UUID albumId;


@ManyToOne


Singer singer;


String albumTitle;


}


此外,还需要为每个实体添加无参数的构造函数 hashCode() 和 equals(),因为 Hibernate 需要这些函数。您可在完整示例中查看全部操作。


此外,在此示例中,我们将使用自动生成的 UUID 作为主键。这是 Cloud Spanner 中的首选 ID 类型,因为其避开了系统按照键范围在服务器之间划分数据时的热点。也可使用单调递增的整数键,但性能可能会下降。


配置好所有内容并定义了实体对象之后,我们即可开始写入数据库。


创建 Hibernate Session。


src/main/java/demo/Application.java


StandardServiceRegistry registry = new StandardServiceRegistryBuilder().configure().build();SessionFactory sessionFactory = new MetadataSources(registry).buildMetadata()        .buildSessionFactory();Session session = sessionFactory.openSession();
复制代码


现在,将一些数据写入 Cloud Spanner。


src/main/java/demo/Application.java


session.beginTransaction();
复制代码


Singer singerMelissa = new Singer(“Melissa”, “Garcia”, makeDate(“1981-03-19”));


Album albumGoGoGo = new Album(singerMelissa, “Go, Go, Go”);


session.save(singerMelissa);


session.save(albumGoGoGo);


session.save(new Singer(“Russell”, “Morales”, makeDate(“1978-12-02”)));


session.save(new Singer(“Jacqueline”, “Long”, makeDate(“1990-07-29”)));


session.save(new Singer(“Dylan”, “Shaw”, makeDate(“1998-05-02”)));


session.getTransaction().commit();


此时,如果您转到 Cloud Spanner 控制台并查看数据库中“歌手”和“专辑”表格的数据,则会看到以下内容:




能够在 Cloud Console 中轻松浏览数据库表很好,但我们还希望能够在自己的应用中查询这些数据库表。因此最后,我们来使用 Hibernate 查询一些数据。请注意,我们使用的是 HQL,其可在各种 Hibernate 方言之间移植,而不仅仅是 Cloud Spanner。


src/main/java/demo/Application.java


 List<Singer> singers =
复制代码


session.createQuery("from Singer where birthDate >= '1990-01-01'").list();
复制代码


Listalbums = session.createQuery(“from Album”).list();


最后,请务必先关闭 Hibernate 资源,然后再关闭应用。


src/main/java/demo/Application.java


session.close();sessionFactory.close();
复制代码


2020-05-26 12:28578

评论

发布
暂无评论
发现更多内容

面试前必刷!Java高级工程师1380道面试题(附答案)分享

架构师之道

Java 面试

测试环境

乌龟哥哥

三周年连更

Java 如何在 Array 和 List 之间进行转换

HoneyMoose

ChatGPT是很强,但也会胡说八道

这我可不懂

人工智能 低代码 ChatGPT

探讨AIGC的崛起历程,浅析其背后技术发展

华为云开发者联盟

人工智能 华为云 AIGC 华为云开发者联盟 企业号 5 月 PK 榜

AI 大底座,大模型时代的答卷

Baidu AICLOUD

大模型训练

怎么在 vue 中使用 form 清除校验状态?

海拥(haiyong.site)

三周年连更

只需要六步!快速开启专属的风控系统

Geek_2d6073

2023一线大厂 Java 面试八股文大全(整理版)附答案详解!

采菊东篱下

Java 面试

从原理到应用,人人都懂的ChatGPT指南 | 京东云技术团队

京东科技开发者

人工智能 AI ChatGPT4 企业号 5 月 PK 榜

Django笔记二十四之数据库函数之比较和转换函数

Hunter熊

Python MySQL django cast

2分钟快速上手流水线的创建与运行

华为云开发者联盟

开发 华为云 华为云开发者联盟 企业号 5 月 PK 榜

什么是人工智能领域的深度学习?

Jerry Wang

人工智能 深度学习 强化学习 三周年连更

云原生日志收集机制和日志处理流程规范

穿过生命散发芬芳

日志分析 三周年连更

Java实现多用户即时通信系统

timerring

Java

LED显示屏行业发展步伐

Dylan

发展 科技 LED显示屏

万字长文——Go 语言现代命令行框架 Cobra 详解

江湖十年

golang 后端 命令行 命令行工具

使用MASA全家桶从零开始搭建IoT平台(三)管理设备的连接状态

MASA技术团队

IoT MASA .NET 7

简单好用的网页设计工具:EverWeb中文版

真大的脸盆

Mac 网页设计 Mac 软件 网页布局 网页制作

Zebec 生态旗下 NFT协议 PlazaDAO宣布进军BRC20生态,有什么规划?

股市老人

Flink的函数体系

阿泽🧸

flink 三周年连更

ChatGPT 中文指令指南,教会你如何使用chatgpt实现中文你想要的答案

汀丶人工智能

ChatGPT

怎样成为优秀的后端工程师

越长大越悲伤

后端、 java‘

持续交付下的分层自动化测试

单东东

DevOps 持续交付 持续测试 测试自动化 junit5

网易伏羲RL4RS荣获SIGIR2023 Resource Paper,推动深度学习技术创新

网易伏羲

小程序开发中的插件、组件、控件,傻傻分不清楚

没有用户名丶

使用NineData定制企业级数据库规范

NineData

数据库 dba 企业管理工具 数据库开发工具 企业级数据库规范

平台工程助力企业提升研发效能

SEAL安全

研发效能 平台工程

音视频八股文(11)-- ffmpeg avio 内存输入和内存输出。内存输出有完整代码,网上很少有的。

福大大架构师每日一题

c ffmpeg 福大大

并发编程:ErrGroup的正确使用

Jack

Java 如何在 Array 和 Set 之间进行转换

HoneyMoose

为 Cloud Spanner 引入 Hibernate ORM 以便使用数据库_开源_Mike Eltsufin_InfoQ精选文章