AICon 上海站|日程100%上线,解锁Al未来! 了解详情
写点什么

Jakarta NoSQL 介绍

  • 2019-10-31
  • 本文字数:2526 字

    阅读完需:约 8 分钟

Jakarta NoSQL介绍

Jakarta NoSQL 是 Jakarta EE 中的一个规范, 最近被批准为 EE4J 项目,它可以帮助开发人员使用 Java 和 NoSQL 技术来创建企业级的应用程序。JNoSQL 是 Jakarta NoSQL 的参考实现,它为一系列 NoSQL 数据库(如CassandraMongoDBNeo4JCouchDBOrientDB等)提供了一组 API 和一个标准实现。


Jakarta NoSQL 是由通信层(Diana)组成的,它提供了一组用于定义与 NoSQL 数据库通信的 API。根据 NoSQL 数据库的不同类型,它包含了四个模块:键值(Key-Value)、列族(Column Family)、文档(Document)和图(Graph);映射层(Artemis)提供了一系列 API 来帮助开发人员将 Java 应用程序与 NoSQL 数据库集成。映射层是注解驱动的,它使用了 CDI 和 Bean Validation 等技术,这使得开发人员使用起来更加简单。也可以将映射层与传统 RDBMS 世界中的 JPA/Hibernate 进行比较。



让我们更深入地探讨一下如何与键值、列族、文档和图等 NoSQL 数据库进行通信。


实体的定义与 JPA 非常相似。基本上也是使用 @Entity、@Id、@Column 等注解:


@Entitypublic class Person {
@Id private long id;
@Column private String name;
@Column private List phones;}
复制代码


存储库和 Spring 的数据存储库看起来很像,可以通过 Repository<T, ID> 进行扩展:


public interface PersonRepository extends Repository {
List<Person> findByName(String name);
Stream<Person> findByPhones(String phone);}
复制代码


现在,我们必须稍微调整一下它,因为 maven 构件会根据 NoSQL 数据库的类型、设置配置以及如何在服务中注入存储库而改变。


我们比较一下列和文档 NoSQL 数据库之间的差异:


列(Column)


Maven 依赖的构件如下:


<dependency>   <groupId>org.jnosql.artemis</groupId>   <artifactId>artemis-column</artifactId>   <version>0.0.9</version></dependency><dependency>   <groupId>org.jnosql.diana</groupId>   <artifactId>cassandra-driver</artifactId>   <version>0.0.9</version></dependency>
复制代码


用于设置 ColumnFamilyManager 生产者的示例如下:


@ApplicationScopedpublic class ColumnFamilyManagerProducer {
private static final String KEY_SPACE = "developers"; private ColumnConfiguration<> cassandraConfiguration; private ColumnFamilyManagerFactory managerFactory;
@PostConstruct public void init() { cassandraConfiguration = new CassandraConfiguration(); managerFactory = cassandraConfiguration.get(); }
@Produces public ColumnFamilyManager getManagerCassandra() { return managerFactory.get(KEY_SPACE); }}
复制代码


最后,是一个如何执行一些插入/查询的示例:


Person person = Person.builder()  .withPhones(Arrays.asList("234", "432"))  .withName("Name")  .withId(id)  .build();
//使用 ColumnTemplateColumnTemplate columnTemplate = container.select(CassandraTemplate.class).get();Person saved = columnTemplate.insert(PERSON);System.out.println("Person saved" + saved);
ColumnQuery query = select().from("Person").where(eq(Column.of("id", 1L))).build();
Optional<Person> person = columnTemplate.singleResult(query);System.out.println("Entity found: " + person);
//使用 PersonRepositoryPersonRepository repository = container.select(PersonRepository.class).select(ofColumn()).get();Person saved = repository.save(PERSON);System.out.println("Person saved" + saved);
Optional<Person> person = repository.findById(1L);System.out.println("Entity found: " + person);
复制代码


文档(Document)


Maven 依赖的构件如下:


<dependency>   <groupId>org.jnosql.artemis</groupId>   <artifactId>artemis-document</artifactId>   <version>0.0.9</version></dependency><dependency>   <groupId>org.jnosql.diana</groupId>   <artifactId>mongodb-driver</artifactId>   <version>0.0.9</version></dependency>
复制代码


用于设置 DocumentCollectionManager 的生产者示例如下:


@ApplicationScopedpublic class DocumentCollectionManagerProducer {
private static final String COLLECTION = "developers"; private DocumentConfiguration configuration; private DocumentCollectionManagerFactory managerFactory;
@PostConstruct public void init() { configuration = new MongoDBDocumentConfiguration(); Map<String, Object> settings = Collections.singletonMap("mongodb-server-host-1", "localhost:27017"); managerFactory = configuration.get(Settings.of(settings)); }
@Produces public DocumentCollectionManager getManager() { return managerFactory.get(COLLECTION); }}
复制代码


最后,是一个如何执行一些插入/查询的示例:


Person person = Person.builder()  .withPhones(Arrays.asList("234", "432"))  .withName("Name")  .withId(id)  .build();
//使用 DocumentTemplateDocumentTemplate documentTemplate = container.select(DocumentTemplate.class).get();Person saved = documentTemplate.insert(person);System.out.println("Person saved" + saved);
DocumentQuery query = select().from("Person") .where(eq(Document.of("_id", id))).build();
Optional<Person> personOptional = documentTemplate.singleResult(query);System.out.println("Entity found: " + personOptional);
//使用 PersonRepositoryPersonRepository repository = container.select(PersonRepository.class) .select(ofDocument()).get();repository.save(person);
List<Person> people = repository.findByName("Name");System.out.println("Entity found: " + people);repository.findByPhones("234").forEach(System.out::println);
复制代码


有关 Jakarta NoSQL 参考实现的更多细节可以在JNoSQL 上找到。


Jakarta One 上还有一个 Jakarta NoSQL 的演示视频。


想要投稿的用户可以订阅邮件列表,或者通过Twitter和我们联系。


原文链接:


Introducing Jakarta NoSQL


2019-10-31 08:002018

评论

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

HarmonyOS next之flutter鸿蒙项目初体验

flfljh

淘宝APP分类API接口:开发、运用与收益全解析

科普小能手

数据挖掘 淘宝 电商 API 接口 API 测试

开源IM聊天程序HarmonyChat:基于鸿蒙NEXT的WebSocket协议

JackJiang

即时通讯;IM;网络编程

CST软件如何计算天线fidelity保真度?达索代理思茂信息

思茂信息

cst cst操作 CST软件

构建AI Agent必学的4种设计模式,一文了解

Baihai IDP

程序员 AI LLMs AI Agents AI 助手

AI赋能产业升级:探索人工智能在不同领域的实际应用

天津汇柏科技有限公司

AI 人工智能

HarmonyOS next之APP 服务卡片获取 APP 内数据

flfljh

VMware ESXi 8.0U3c macOS Unlocker & OEM BIOS 集成驱动版,新增 12 款 I219 网卡驱动

sysin

esxi

智慧人大综合管理平台(源码+文档+部署+讲解)

深圳亥时科技

2024年终福利 | Apache DolphinScheduler案例合集,附PDF下载

白鲸开源

Apache DolphinScheduler 大数据 开源 案例集 大数据调度

VUE3与JNPF快速开发平台的完美结合

伤感汤姆布利柏

艾卡货车救援系统(源码+文档+部署+讲解)

深圳亥时科技

京东供应链创新与实践:应用数据驱动的库存选品和调拨算法提升履约效率

京东科技开发者

白鲸开源WhaleStudio荣获2024星空奖!

白鲸开源

datafun 数据集成平台 大数据调度 白鲸开源 星空奖

面向教育场景的大模型 RAG 检索增强解决方案

阿里云大数据AI技术

人工智能 大模型 LLM rag PAI

GDP一直在增长,为什么钱却这么难挣

博文视点Broadview

AI技术在英语学习领域的应用

北京木奇移动技术有限公司

AI教育 软件外包公司 AI英语学习

Helm适配华为云OBS实践分享,更方便地部署、管理复杂应用

华为云开发者联盟

开源 Kubernetes Helm OBS

VMware ESXi 8.0U3c macOS Unlocker & OEM BIOS xFusion (超聚变) 定制版

sysin

每年一问:Java日期格式化中周所在年引发的bug

白鲸开源

开源 Apache DolphinScheduler 日期 大数据调度

GreatSQL temp文件占用时长分析

GreatSQL

《计算机组成及汇编语言原理》阅读笔记:p178-p199

codists

计算机组成及汇编语言原理

LED和LCD的15个不同之处

Dylan

LCD1602液晶显示屏 LED LED display LED显示屏 lcd

由 Mybatis 源码畅谈软件设计(九):“能用就行” 其实远远不够

京东科技开发者

业务监控—一站式搭建jmeter+telegraf+influxdb+Grafana看板

京东科技开发者

2024年Apache DolphinScheduler社区高光时刻总结!

白鲸开源

Apache DolphinScheduler 2024年终总结

行业分享丨延锋国际基于数据分析和AI平台的仿真工具探索

Altair RapidMiner

人工智能 数据挖掘 数据分析 AI在仿真应用 ai与cae

Altair助力著名工业电子控制系统供应商Psicontrol提升PCB开发流程效率

Altair RapidMiner

EMC 电子设计 电磁仿真 PCB开发 FEKO

HarmonyOS next之Flutter插件支持鸿蒙系

flfljh

Jakarta NoSQL介绍_编程语言_Diogo Carleto_InfoQ精选文章