写点什么

为 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:28891

评论

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

如何通过服务提升产品价值?

石云升

产品思维 体验设计 产品分析 2月月更 服务产品化

互联网产品管理课-笔记(16/100)

hackstoic

产品

权威可信 | 华为云云测通过中国电子技术标准院软件测试工具能力评价

华为云开发者联盟

软件测试 测试 华为云 测试工具 华为云云测

过完年了, 为明年设计一个春联自动生成器, 给大家助助兴

DS小龙哥

2月月更

作业8

施正威

跨平台应用开发进阶(五) :uni-app 实现列表项左划操作

No Silver Bullet

uni-app 2月月更 左划删除

模块八

Only

架构师实战营 「架构实战营」

简谈什么是 Web 3.0

devpoint

元宇宙 Web3.0 2月月更

掌握这20个JS技巧,做一个不加班的前端人

华为云开发者联盟

JavaScript 数组 箭头函数 逻辑运算符 计数器对象

亿级数据量场景下,如何优化数据库分页查询方法

华为云开发者联盟

MySQL 缓存 查询 数据表 分页查询

攻克MySQL—索引优化

javaadu

MySQL 面试题 索引

SSR 和前端编译,在这点上是一样的

CRMEB

从俄乌战争看区块链技术在未来国防领域的应用

CECBC

实践GoF的23种设计模式:SOLID原则

元闰子

设计模式 SOLID

NFT盲盒商城系统开发技术

薇電13242772558

NFT

精选22个pandas实用函数

Peter

Python 数据分析 pandas

一次历史漏洞分析与复现的全部过程

H

网络安全

攻克MySQL-索引基础

javaadu

MySQL 面试题 索引

梦幻联动!金蝶&华为云面向大企业发布数据库联合解决方案

华为云开发者联盟

数据库 华为云 数据管理 GaussDB(for openGauss) 金蝶

学生管理系统详细架构设计

Geek_8d5fe5

架构实战营

mxGraph教程-开发入门指南

No Silver Bullet

流程图 2月月更 mxGraph

【干货】Servlet内存马加载流程分析

网络安全学海

黑客 网络安全 信息安全 渗透测试 安全漏洞

设计千万级学生管理系统的考试试卷存储方案

王大胖

【ELT.ZIP】OpenHarmony啃论文俱乐部——综述视角解读压缩编码

ELT.ZIP

鸿蒙 OpenHarmony 数据压缩

书单

林逸民

学习 读书

人大代表谈“元宇宙”:把握机遇,加速布局

CECBC

能源产业数字化转型:区块链如何“炼”?

CECBC

Go 语言入门很简单:Go 反射

宇宙之一粟

Pandas+Seaborn+Plotly:联手探索苹果AppStore

Peter

数据挖掘 数据分析 可视化 Kaggle

【Python】这个列表TTT熟悉

謓泽

Python 2月月更

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