表格存储 Java SDK 开发入门

本文涉及的产品
表格存储 Tablestore,50G 2个月
简介: 本文将结合电商订单场景为例,介绍表格存储 Tablestore Java SDK 的基本使用方法。

准备工作

在您开始Tablestore SDK开发前,需确保已开通表格存储服务并且已创建表格存储实例。

您需要提前获取到以下几个参数


开发简介

开发示例中将以订单场景为例,使用Tablestore SDK实现如下几个功能。

  • 订单表创建。
  • 订单插入。
  • 订单号查询。
  • 订单搜索。


字段名

字段类型

字段描述

order_id

String

主键

订单号

customer_name

String

属性列

消费者姓名

product_name

String

属性列

产品名

product_type

String

属性列

产品类型

order_time

String

属性列

下单时间

pay_time

String

属性列

支付时间

订单表

开发步骤

初始化连接

Tablestore支持Http/Https协议访问服务端,使用Java SDK发起请求前,您需要初始化一个OTSClinet实例,初始化需要获取到服务地址(endpoint)、实例名(instanceName)、密钥(accessKeyId、accessSecret)等信息。代码如下

publicstaticvoidmain(String[] args) {
SyncClientsyncClient=newSyncClient(
"https://order-instance.cn-beijing.ots.aliyuncs.com",//your endpoint,此处可选择公网地址"",//your accessKeyId"",//your accessSecret"order-instance");//your instance name//operation_method(syncClinet);//operation method}


创建数据表

示例代码中创建了一张订单数据表order。

publicstaticvoidcreateOrderTable(SyncClientsyncClient){
TableOptionstableOptions=newTableOptions();
tableOptions.setMaxVersions(1);
tableOptions.setTimeToLive(-1);
TableMetatableMeta=newTableMeta("order");//设置表名tableMeta.addPrimaryKeyColumn("order_id",PrimaryKeyType.STRING);//设置主键CreateTableRequestcreateTableRequest=newCreateTableRequest(tableMeta,tableOptions);
syncClient.createTable(createTableRequest);//发送创建表请求System.out.println("create order table succeed");
    }

写入数据

示例代码中写入了一条订单数据,订单号order_id为“o1”。样例中模拟了一万条订单数据,这里不作展示。

publicstaticvoidputOrder(SyncClientsyncClient){
RowPutChangerowPutChange=newRowPutChange("order");//设置表名rowPutChange.setPrimaryKey(PrimaryKeyBuilder.createPrimaryKeyBuilder()
                .addPrimaryKeyColumn("order_id",PrimaryKeyValue.fromString("o1"))//设置主键                .build());
rowPutChange.addColumns(Arrays.asList(
newColumn("customer_name",ColumnValue.fromString("消十一")),//设置属性列信息newColumn("product_name",ColumnValue.fromString("iphone 6")),
newColumn("product_type",ColumnValue.fromString("手机")),
newColumn("order_time",ColumnValue.fromString("2021-10-25 09:20:01")),
newColumn("pay_time",ColumnValue.fromString("2017-10-25 10:00:01"))
        ));
syncClient.putRow(newPutRowRequest(rowPutChange));//发送插入数据请求System.out.println("put order succeed");
    }

查询数据

示例代码中查询订单号order_id为“o1”的记录

 

publicstaticvoidgetOrder(SyncClientsyncClient){
SingleRowQueryCriteriacriteria=newSingleRowQueryCriteria("order");//设置表名criteria.setPrimaryKey(PrimaryKeyBuilder.createPrimaryKeyBuilder()
                .addPrimaryKeyColumn("order_id",PrimaryKeyValue.fromString("o1"))//设置主键                .build());
criteria.setMaxVersions(1);
GetRowResponseresponse=syncClient.getRow(newGetRowRequest(criteria));//发送读取数据请求System.out.println(response.getRow());
    }

创建多元索引

示例代码中创建了一个多元索引order_index。分别设置customer_name字符串类型、order_time字符串类型、pay_time字符串类型、product_name分词类型、product_type字符串类型。关于索引字段类型的介绍请参考多元索引概述

publicstaticvoidcreateSearchIndex(SyncClientsyncClient){
CreateSearchIndexRequestcreateSearchIndexRequest=newCreateSearchIndexRequest("order","order_index");//设置表名和索引名IndexSchemaindexSchema=newIndexSchema();
indexSchema.setFieldSchemas(Arrays.asList(//设置索引结构newFieldSchema("customer_name",FieldType.KEYWORD),
newFieldSchema("order_time",FieldType.KEYWORD),
newFieldSchema("pay_time",FieldType.KEYWORD),
newFieldSchema("product_name",FieldType.TEXT),
newFieldSchema("product_type",FieldType.KEYWORD)
        ));
createSearchIndexRequest.setIndexSchema(indexSchema);
syncClient.createSearchIndex(createSearchIndexRequest);//发送创建索引请求System.out.println("create search index succeed");
    }

搜索数据

示例代码中查询产品类型为“手机”的订单,并统计了符合条件的行数。

publicstaticvoidsearchQuery1(SyncClientsyncClient){
SearchRequestsearchRequest=SearchRequest.newBuilder()
                .tableName("order").indexName("order_index")//设置表名、索引名                .searchQuery(SearchQuery.newBuilder()
                        .query(QueryBuilders.term("product_type","手机"))//查询类型为手机的记录                        .getTotalCount(true)//获取查询命中的行数                        .build())
                .returnAllColumns(true)
                .build();
SearchResponseresponse=syncClient.search(searchRequest);
System.out.println("total rows:"+response.getTotalCount());
for(Rowrow : response.getRows()){
System.out.println(row);
        }
    }

示例代码中搜索产品名包含“iphone”的订单,并统计了符合条件的行数。

publicstaticvoidsearchQuery2(SyncClientsyncClient){
SearchRequestsearchRequest=SearchRequest.newBuilder()
                .tableName("order").indexName("order_index")//设置表名、索引名                .searchQuery(SearchQuery.newBuilder()
                        .query(QueryBuilders.match("product_name","iphone"))//搜索产品名中包含iphone的行                        .getTotalCount(true)//获取查询命中的行数                        .build())
                .returnAllColumns(true)
                .build();
SearchResponseresponse=syncClient.search(searchRequest);
System.out.println("total rows:"+response.getTotalCount());
for(Rowrow : response.getRows()){
System.out.println(row);
        }
    }

示例代码中查询了消费者姓名为“消十一”并且下单时间在“2021-10-24 00:00:00”之间的订单。并统计了行数。

publicstaticvoidsearchQuery3(SyncClientsyncClient){
SearchRequestsearchRequest=SearchRequest.newBuilder()
                .tableName("order").indexName("order_index")//设置表名、索引名                .searchQuery(SearchQuery.newBuilder()
                        .query(QueryBuilders.bool()
                                .must(QueryBuilders.term("customer_name","消十一"))
                                .must(QueryBuilders.range("order_time").lessThan("2021-10-24 00:00:00")))
                        .getTotalCount(true)//获取查询命中的行数                        .build())
                .returnAllColumns(true)
                .build();
SearchResponseresponse=syncClient.search(searchRequest);
System.out.println("total rows:"+response.getTotalCount());
for(Rowrow : response.getRows()){
System.out.println(row);
        }
    }

删除多元索引

示例代码中展示了删除订单表order中的order_index多元索引。

publicstaticvoiddeleteSearchIndex(SyncClientsyncClient){
DeleteSearchIndexRequestdeleteSearchIndexRequest=newDeleteSearchIndexRequest();
deleteSearchIndexRequest.setTableName("order");
deleteSearchIndexRequest.setIndexName("order_index");
syncClient.deleteSearchIndex(deleteSearchIndexRequest);
System.out.println("delete search index succeed");
    }

删除数据表

示例代码中展示了删除订单表order。删除表之前需确保先删除表中的多元索引。

publicstaticvoiddeleteTable(SyncClientsyncClient){
syncClient.deleteTable(newDeleteTableRequest("order"));//发送删除数据表请求System.out.println("delete table succeed");
    }

更多关于Tablestore JAVA SDK的介绍请参考Tablestore JAVA SDK

相关实践学习
消息队列+Serverless+Tablestore:实现高弹性的电商订单系统
基于消息队列以及函数计算,快速部署一个高弹性的商品订单系统,能够应对抢购场景下的高并发情况。
阿里云表格存储使用教程
表格存储(Table Store)是构建在阿里云飞天分布式系统之上的分布式NoSQL数据存储服务,根据99.99%的高可用以及11个9的数据可靠性的标准设计。表格存储通过数据分片和负载均衡技术,实现数据规模与访问并发上的无缝扩展,提供海量结构化数据的存储和实时访问。 产品详情:https://www.aliyun.com/product/ots
目录
相关文章
|
1月前
|
监控 Java API
如何使用Java语言快速开发一套智慧工地系统
使用Java开发智慧工地系统,采用Spring Cloud微服务架构和前后端分离设计,结合MySQL、MongoDB数据库及RESTful API,集成人脸识别、视频监控、设备与环境监测等功能模块,运用Spark/Flink处理大数据,ECharts/AntV G2实现数据可视化,确保系统安全与性能,采用敏捷开发模式,提供详尽文档与用户培训,支持云部署与容器化管理,快速构建高效、灵活的智慧工地解决方案。
|
20天前
|
Java 开发者 微服务
Spring Boot 入门:简化 Java Web 开发的强大工具
Spring Boot 是一个开源的 Java 基础框架,用于创建独立、生产级别的基于Spring框架的应用程序。它旨在简化Spring应用的初始搭建以及开发过程。
38 6
Spring Boot 入门:简化 Java Web 开发的强大工具
|
8天前
|
存储 JavaScript 前端开发
基于 SpringBoot 和 Vue 开发校园点餐订餐外卖跑腿Java源码
一个非常实用的校园外卖系统,基于 SpringBoot 和 Vue 的开发。这一系统源于黑马的外卖案例项目 经过站长的进一步改进和优化,提供了更丰富的功能和更高的可用性。 这个项目的架构设计非常有趣。虽然它采用了SpringBoot和Vue的组合,但并不是一个完全分离的项目。 前端视图通过JS的方式引入了Vue和Element UI,既能利用Vue的快速开发优势,
55 13
|
13天前
|
算法 Java API
如何使用Java开发获得淘宝商品描述API接口?
本文详细介绍如何使用Java开发调用淘宝商品描述API接口,涵盖从注册淘宝开放平台账号、阅读平台规则、创建应用并申请接口权限,到安装开发工具、配置开发环境、获取访问令牌,以及具体的Java代码实现和注意事项。通过遵循这些步骤,开发者可以高效地获取商品详情、描述及图片等信息,为项目和业务增添价值。
46 10
|
6天前
|
前端开发 Java 测试技术
java日常开发中如何写出优雅的好维护的代码
代码可读性太差,实际是给团队后续开发中埋坑,优化在平时,没有那个团队会说我专门给你一个月来优化之前的代码,所以在日常开发中就要多注意可读性问题,不要写出几天之后自己都看不懂的代码。
42 2
|
16天前
|
监控 架构师 Java
Java虚拟机调优的艺术:从入门到精通####
本文作为一篇深入浅出的技术指南,旨在为Java开发者揭示JVM调优的神秘面纱,通过剖析其背后的原理、分享实战经验与最佳实践,引领读者踏上从调优新手到高手的进阶之路。不同于传统的摘要概述,本文将以一场虚拟的对话形式,模拟一位经验丰富的架构师向初学者传授JVM调优的心法,激发学习兴趣,同时概括性地介绍文章将探讨的核心议题——性能监控、垃圾回收优化、内存管理及常见问题解决策略。 ####
|
16天前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
1月前
|
开发框架 Java 关系型数据库
Java哪个框架适合开发API接口?
在快速发展的软件开发领域,API接口连接了不同的系统和服务。Java作为成熟的编程语言,其生态系统中出现了许多API开发框架。Magic-API因其独特优势和强大功能,成为Java开发者优选的API开发框架。本文将从核心优势、实际应用价值及未来展望等方面,深入探讨Magic-API为何值得选择。
42 2
|
1月前
|
监控 前端开发 Java
【技术开发】接口管理平台要用什么技术栈?推荐:Java+Vue3+Docker+MySQL
该文档介绍了基于Java后端和Vue3前端构建的管理系统的技术栈及功能模块,涵盖管理后台的访问、登录、首页概览、API接口管理、接口权限设置、接口监控、计费管理、账号管理、应用管理、数据库配置、站点配置及管理员个人设置等内容,并提供了访问地址及操作指南。
|
1月前
|
IDE Java 编译器
开发 Java 程序一定要安装 JDK 吗
开发Java程序通常需要安装JDK(Java Development Kit),因为它包含了编译、运行和调试Java程序所需的各种工具和环境。不过,某些集成开发环境(IDE)可能内置了JDK,或可使用在线Java编辑器,无需单独安装。
65 1
下一篇
DataWorks