表格存储Tablestore入门手册系列主要介绍表格存储的各个功能接口和适用场景,帮助客户了解和使用表格存储Tablestore。本文对表格存储Tablestore的UpdateRow接口进行介绍,包括其参数、功能示例、使用场景等。

接口概述

UpdateRow接口是表格存储Tablestore提供的基础读写接口之一,用于对某一行进行更新操作,若指定行不存在,UpdateRow也可以用于新增一行。这里的更新包括新增、修改或删除某一列,如果使用了多版本功能,也可以对某列中指定的版本进行新增、修改或删除。此外,在接口参数中也可以指定条件,仅当满足条件时进行更新。下面详细介绍该接口的参数和功能。

接口参数说明

API定义和参数说明

首先是UpdateRow接口的API定义:

message UpdateRowRequest {required string table_name = 1;required bytes row_change = 2;required Condition condition = 3;optional ReturnContent return_content = 4;
}message UpdateRowResponse {required ConsumedCapacity consumed = 1;optional bytes row = 2;
}

API定义中的具体参数说明,见官网API文档:https://help.aliyun.com/document_detail/27307.html

SDK接口和参数说明

在项目代码中对表格存储Tablestore进行读写操作,是通过表格存储Tablestore发布的各语言SDK进行的,SDK对API进行了封装,内部自动处理了请求的编码和响应的解析等。因此对于表格存储Tablestore的使用者来说,只需要熟悉SDK的接口即可。

下面以Java SDK为例,介绍SDK中的UpdateRow接口和参数。

接口定义

同步接口(SyncClient):

    /*** 更新表中的一行数据。* <p>若要更新的行不存在,则新写入一行数据。</p>* <p>更新操作可以包括新写入一个属性列或者删除一个属性列的一个或多个版本。</p>** @param updateRowRequest 执行UpdateRow操作所需的参数。* @return TableStore服务返回的结果* @throws TableStoreException    TableStore服务返回的异常* @throws ClientException 请求的返回结果无效、或遇到网络异常*/public UpdateRowResponse updateRow(UpdateRowRequest updateRowRequest)throws TableStoreException, ClientException;

异步接口(AsyncClient):

    /*** 更新表中的一行数据。* <p>若要更新的行不存在,则新写入一行数据。</p>* <p>更新操作可以包括新写入一个属性列或者删除一个属性列的一个或多个版本。</p>** @param updateRowRequest 执行UpdateRow操作所需的参数。* @param callback 请求完成后调用的回调函数,可以为null,则代表不需要执行回调函数* @return 获取结果的Future* @throws TableStoreException TableStore服务返回的异常* @throws ClientException 请求的返回结果无效、或遇到网络异常*/public Future<UpdateRowResponse> updateRow(UpdateRowRequest updateRowRequest, TableStoreCallback<UpdateRowRequest, UpdateRowResponse> callback);

具体参数说明:

变量类型 说明 备注
UpdateRowRequest UpdateRow接口的请求类型,具体内容见后续说明。  
UpdateRowResponse UpdateRow接口的返回结果,具体内容见后续说明。  
TableStoreCallback callback UpdateRow接口的异步回调函数。 仅适用于异步接口。
Future 异步接口的UpdateRow接口返回结果。 仅适用于异步接口。
异步接口调用后不等待请求结束,立即返回future,通过future.get()可以获取实际接口响应的结果。

UpdateRowRequest参数说明

具体参数说明:

变量类型 说明 备注
TxnRequest(基类) 抽象类,包含TransactionId成员变量,继承该类的请求类型可用于局部事务中。 TransactionId的使用可参考局部事务的文档。
UpdateRowRequest UpdateRow接口的请求类型,包含一个成员变量:RowUpdateChange。
继承自TxnRequest,表示该请求可用于局部事务中。
 
RowUpdateChange 本次更新的具体请求参数。  

RowUpdateChange参数说明

具体参数说明:

变量类型 类说明 成员变量或接口 说明
RowChange(基类) RowUpdateChange的基类,提供了设置表名、主键、更新条件、返回类型等通用参数。 tableName 指定本次更新要操作的表名。
    primaryKey 指定本次要更新的行的主键。
    condition 指定本次更新操作的条件,可选。
    returnType 枚举类型,默认为RT_NONE,表示不返回行的内容,此外还有两种值:
(1)RT_PK: 返回主键,适用于使用主键自增列功能的场景,用于返回系统生成的自增主键值。
(2)RT_AFTER_MODIFY: 返回修改的列的数据,适用于使用了原子加功能的场景,用于返回原子加之后,某一列的值。此时需要设置returnColumnNames。
    returnColumnNames 当returnType为RT_AFTER_MODIFY时,指定要返回的被修改的列的列名(适用于原子加的场景)。
RowUpdateChange UpdateRow的具体请求参数,继承自RowChange类。 put(String columnName, ColumnValue value) 新增或修改某一列的值。
(系统内部会为该列生成一个新的版本号,单版本模式下无须关心该版本号)
    put(String columnName, ColumnValue value, long version) 新增或修改某一列的某一个版本。
(适用于多版本模式,手动指定版本号写入)
    put(Column column) 功能同上述put接口,只是参数使用Column类型进行了封装。
    put(List column) 功能同上述put接口,只是参数为多列。
    deleteColumns(String columnName) 删除某列,多版本模式下会删除该列全部版本。
    deleteColumn(String columnName, long version) 删除某列的指定版本,适用于多版本模式下对特定版本进行删除。
    increment(Column column) 对某列进行原子加操作,仅适用于整型类型。
Condition 本次更新的条件。可以指定行存在性条件和列条件,列条件比如“某列的值大于5”。 rowExistenceExpectation 行存在性条件,枚举类型,有以下三种值:
(1) IGNORE:不对行存在性进行判断,默认即为IGNORE。
(2) EXPECT_EXIST: 期望该行存在,若不存在,请求会报错。
(3) EXPECT_NOT_EXIST:期望该行不存在,若存在,请求会报错。
注意:
通常情况下,若没有特殊的设置条件的需求,使用IGNORE即可(保持默认,可不做设置),此时写入性能也更好。
    columnCondition 列条件,可以设置单列条件(SingleColumnValueCondition),也可以设置多列组合条件(CompositeColumnValueCondition),具体见条件更新的文档。

UpdateRowResponse参数说明

具体参数说明:

变量类型 成员变量或接口 说明
Response(基类) requestId 本次请求服务端返回的requestId,用于问题调查,建议在出错时打印到业务日志中。
  traceId 本次请求SDK生成的traceId,用于问题调查,建议在出错时打印到业务日志中。
UpdateRowResponse consumedCapacity 本次请求消耗的读写CU,用于计费。
  row 默认情况下为null,仅当请求中returnType设置为返回PK(RT_PK)或者某列修改后的值(RT_AFTER_MODIFY)时,返回对应的内容。

功能示例

所有示例代码可以在Tablestore-Examples项目中查看。

Github地址:https://github.com/aliyun/tablestore-examples/tree/master/basic/Java/DataManage/src/main/java/com/aliyun/tablestore/basic/dataManage

基本更新操作

UpdateRow接口最常用的场景,是对某一行写入一些列,或者删除一些列。通常,业务使用单版本表比较多,此时可以忽略列上多版本的概念,按照每列只有一个值来理解。此时UpdateRow就是用于新增、修改或删除某些列。

新增:若写入的属性列之前不存在,UpdateRow执行后会新增该列。
修改:若写入的属性列之前已经有值,UpdateRow执行后会修改该列的值。
删除:UpdateRow可以用于删除某些列,若该列之前就不存在,则无影响,不会报错。

示例代码

下面的代码执行一次UpdateRow操作,对某一行新增两列,删除一列。

    public void updateRowNormally() {PrimaryKey primaryKey = PrimaryKeyBuilder.createPrimaryKeyBuilder().addPrimaryKeyColumn(PK1, PrimaryKeyValue.fromLong(1L)).addPrimaryKeyColumn(PK2, PrimaryKeyValue.fromString("string")).build();/*** 构造RowUpdateChange,设置表名和主键*/RowUpdateChange rowChange = new RowUpdateChange(TABLE_NAME, primaryKey);/*** 写入两列*/rowChange.put("col_str", ColumnValue.fromString("value1"));rowChange.put("col_long", ColumnValue.fromLong(1));/*** 删除某列*/rowChange.deleteColumns("col_to_delete");/*** 构造UpdateRowRequest*/UpdateRowRequest updateRowRequest = new UpdateRowRequest(rowChange);/*** 调用updateRow接口。若之前该行不存在,系统会新增该行。*/UpdateRowResponse updateRowResponse = syncClient.updateRow(updateRowRequest);/*** 打印requestID*/System.out.printf("UpdateRowSuccess, request id: %s\n", updateRowResponse.getRequestId());}

使用UpdateRow新增、修改或者删除某些列,是最基础的单行数据更新操作,也是很常用的场景。

但在某些场景中,若使用了表格存储Tablestore的多版本功能,可能会有新增或修改某一列的某个特定版本的需求,或者是需要删除某一列的某一个版本,此时就需要指定时间戳来更新或删除,见下面的示例。

指定版本操作

对于设置了保留多版本的表,每一列上都会保留最新的N个版本,UpdateRow可以对其中某个特定版本进行更新,也可以删除某个特定版本。

示例代码

下面的代码执行一次UpdateRow操作,对某一行写入两列,指定版本号写入,同时删除某列的某个版本,也需要指定要删除的版本号。

注意:在指定版本号时,需要保证该版本号在表上设置的最大版本偏差内,若超出该偏差范围,可以调整表上的最大版本偏差设置。

    public void updateRowMultiVersion() {PrimaryKey primaryKey = PrimaryKeyBuilder.createPrimaryKeyBuilder().addPrimaryKeyColumn(PK1, PrimaryKeyValue.fromLong(1L)).addPrimaryKeyColumn(PK2, PrimaryKeyValue.fromString("string")).build();/*** 构造RowUpdateChange,设置表名和主键*/RowUpdateChange rowChange = new RowUpdateChange(TABLE_NAME, primaryKey);long version = System.currentTimeMillis();/*** 写入两列,指定版本号。* 若指定的版本之前不存在,则会新增一个版本;若该版本已存在,会修改该版本的值。*/rowChange.put("col_str", ColumnValue.fromString("value1"), version);rowChange.put("col_long", ColumnValue.fromLong(1), version);/*** 删除某列的某一个版本,指定版本号。*/rowChange.deleteColumn("col_to_delete", version);/*** 构造UpdateRowRequest*/UpdateRowRequest updateRowRequest = new UpdateRowRequest(rowChange);/*** 调用updateRow接口。若之前该行不存在,系统会新增该行。*/UpdateRowResponse updateRowResponse = syncClient.updateRow(updateRowRequest);/*** 打印requestID*/System.out.printf("UpdateRowSuccess, request id: %s\n", updateRowResponse.getRequestId());}

条件更新

UpdateRow接口可以设置更新条件,仅当满足条件时才进行更新,条件包括行存在性条件和列条件。

行存在性条件:在更新前检查该行存在或不存在,仅当符合期望时才进行更新操作,否则抛错。

列条件:目前支持 SingleColumnValueCondition 和 CompositeColumnValueCondition,是基于某一列或者某些列的列值进行条件判断,比如“col_long的值应该大于5”等。基于列条件,可以使用表格存储Tablestore实现分布式的乐观锁机制。

条件更新的功能文档:https://help.aliyun.com/document_detail/35194.html

示例代码

设置行存在性条件和列条件:

    public void updateRowWithCondition() {PrimaryKey primaryKey = PrimaryKeyBuilder.createPrimaryKeyBuilder().addPrimaryKeyColumn(PK1, PrimaryKeyValue.fromLong(1L)).addPrimaryKeyColumn(PK2, PrimaryKeyValue.fromString("string")).build();/*** 构造RowUpdateChange,设置表名和主键*/RowUpdateChange rowChange = new RowUpdateChange(TABLE_NAME, primaryKey);/*** 设置行存在条件为期望行存在*/Condition condition = new Condition(RowExistenceExpectation.EXPECT_EXIST);/*** 设置列条件,若只需要检查行存在性,可以不设置列条件。** 这里设置列条件为两列的组合条件: "(col_boolean == true) && (col_long > 0)"*/CompositeColumnValueCondition colCondition = new CompositeColumnValueCondition(CompositeColumnValueCondition.LogicOperator.AND);SingleColumnValueCondition subColCondition1 = new SingleColumnValueCondition("col_boolean",SingleColumnValueCondition.CompareOperator.EQUAL,ColumnValue.fromBoolean(true));subColCondition1.setPassIfMissing(true); // setPassIfMissing(true),表示若该列不存在,也视为满足条件。SingleColumnValueCondition subColCondition2 = new SingleColumnValueCondition("col_long",SingleColumnValueCondition.CompareOperator.GREATER_THAN,ColumnValue.fromLong(0L));colCondition.addCondition(subColCondition1).addCondition(subColCondition2);subColCondition2.setPassIfMissing(false); // setPassIfMissing(false),表示若该列不存在,视为不满足条件。condition.setColumnCondition(colCondition);rowChange.setCondition(condition);/*** 满足条件时,写入两列*/rowChange.put("col_str", ColumnValue.fromString("value1"));rowChange.put("col_long", ColumnValue.fromLong(1));/*** 构造UpdateRowRequest*/UpdateRowRequest updateRowRequest = new UpdateRowRequest(rowChange);/*** 调用updateRow接口。* 若不满足设置的条件,比如该行不存在,或者不满足列条件,会抛OTSException,ErrorCode为"OTSConditionCheckFail".*/UpdateRowResponse updateRowResponse = syncClient.updateRow(updateRowRequest);/*** 打印requestID*/System.out.printf("UpdateRowSuccess, request id: %s\n", updateRowResponse.getRequestId());}

原子计数器

UpdateRow支持对某一整型列进行原子加操作,原子加操作可以原子的对某一整型列的数据进行增量变更操作,比如在原来的基础上加10,或者减5,等等。原子加操作可以用来构造原子计数器。

原子计数器的功能文档:https://help.aliyun.com/document_detail/90949.html

示例代码

    public void updateRowIncrement() {PrimaryKey primaryKey = PrimaryKeyBuilder.createPrimaryKeyBuilder().addPrimaryKeyColumn(PK1, PrimaryKeyValue.fromLong(1L)).addPrimaryKeyColumn(PK2, PrimaryKeyValue.fromString("string")).build();/*** 构造RowUpdateChange,设置表名和主键*/RowUpdateChange rowChange = new RowUpdateChange(TABLE_NAME, primaryKey);String columnName = "col_long";/*** 对col_long这一列进行原子加100操作。* 若该列之前不存在,会从0开始累加。*/rowChange.increment(new Column(columnName, ColumnValue.fromLong(100)));/*** 设置返回修改后的该列值。*/rowChange.setReturnType(ReturnType.RT_AFTER_MODIFY);rowChange.addReturnColumn(columnName);/*** 构造UpdateRowRequest*/UpdateRowRequest updateRowRequest = new UpdateRowRequest(rowChange);/*** 调用updateRow接口。若之前该行不存在,系统会新增该行。*/UpdateRowResponse updateRowResponse = syncClient.updateRow(updateRowRequest);/*** 打印修改后的该列的值和RequestId*/System.out.printf("UpdateRowSuccess, column [%s] was updated to %d, request id: %s\n",columnName,updateRowResponse.getRow().getLatestColumn(columnName).getValue().asLong(),updateRowResponse.getRequestId());}

原文链接
本文为阿里云原创内容,未经允许不得转载。

Tablestore入门手册-UpdateRow接口详解相关推荐

  1. 完全手册-MATLAB使用详解:基础、开发及工程应用

    [书名]完全手册-MATLAB使用详解:基础.开发及工程应用 [作者]董霖 编著 [ISBN]978-7-121-07397-7 [出版社]电子工业出版社 [出版日期]2009年1月 [内容简介] M ...

  2. Linux - 手册(manual)使用 详解

    手册(manual)使用 详解 本文地址: http://blog.csdn.net/caroline_wendy/article/details/22664555 环境: Ubuntu 12.04 ...

  3. I.MX8M mini物联网开发板框架及屏幕接口详解

    本文由用户robe.zhang发表于电路城论坛试用板块  主要内容: 1.imx8m mini 框架 2.核心板系统框架 3.开发板系统框架 4.屏幕接口详解 5.总结 1.imx8m mini 框架 ...

  4. 【区块链开发入门】(四) Truffle详解篇2

    由于本篇篇幅较长,因此转为两篇文章.Truffle详解篇篇1请见:link 目录导航页 [区块链开发入门](一) 以太坊的搭建与运行 [区块链开发入门](二) 以太坊的编程接口 [区块链开发入门](三 ...

  5. Java6.0中Comparable接口与Comparator接口详解

    Java6.0中Comparable接口与Comparator接口详解 说到现在,读者应该对Comparable接口有了大概的了解,但是为什么又要有一个Comparator接口呢?难道Java的开发者 ...

  6. IDEA 入门:安装使用详解(创建项目/包/类、运行/关闭/导入项目、字体/字号设置、常用快捷键等)

    文章目录 前言 一.创建新项目 Project 1.1.选择"Create New Project" 1.2.选择左下角的"Empty Project" 1.3 ...

  7. 【java8新特性】——lambda表达式与函数式接口详解(一)

    一.简介 java8于2014年发布,相比于java7,java8新增了非常多的特性,如lambda表达式.函数式接口.方法引用.默认方法.新工具(编译工具).Stream API.Date Time ...

  8. html5硬件接口,HTML5通用接口详解

    1.先说几个基本类型: DOMString, boolean, long, unsigned long, double,BmBHTML5中文学习网 - HTML5先行者学习网 NaN(Not-a-Nu ...

  9. 爬虫入门之urllib库详解(二)

    爬虫入门之urllib库详解(二) 1 urllib模块 urllib模块是一个运用于URL的包 urllib.request用于访问和读取URLS urllib.error包括了所有urllib.r ...

最新文章

  1. 栈和队列--算法设计题3.15
  2. MyBatis-07MyBatis注解方式之@Select
  3. thinkphp模版常量替换机制
  4. 选一种比较熟悉的软件,点评它的优缺点,并描述此类软件的发展历史
  5. Linux网络协议栈:关闭一个还有没发送数据完的TCP连接
  6. python抓取汤不热视频_你们想要的 Tumblr 爬虫
  7. [转载] java简易爬虫Crawler
  8. OPEN SQL中通配符的使用
  9. Windows下同步工具FastCopy
  10. vue生成静态html文件_Vue项目打包成一个HTML文件(包含CSS,JS)
  11. Tips--解决Deepin20系统安装完毕无WiFi问题
  12. win7系统打开打印机服务器,Win7如何开启打印机服务?
  13. 最新杭州地铁开通时间表
  14. 用于图像分割的卷积神经网络:从R-CNN到Mask R-CNN
  15. 计算机方向键是哪个键,left键是哪个键
  16. 利用 pinyin4j 把汉字转化为拼音
  17. 运维(32) Prometheus+Grafana监控SpringBoot
  18. 关于Duilib的扩展——“拖放”实现(二)
  19. 数据结构 7 基础排序算法详解 鸡尾酒排序法、了解钟摆排序实现
  20. Python 基础 2-1 列表入门

热门文章

  1. ftm模块linux驱动,飞思卡尔k系列_ftm模块详解.doc
  2. bootstrap table格式化字符串_你要的PHP字符串处理函数都在这了!
  3. linux 控制终端卡,配置通过串口控制linux操作系统的终端
  4. oracle数据库连接检查,检查Oracle数据库的最大连接
  5. scrapy框架_Python:Scrapy框架
  6. mysql 语句 集锦_mysql 语句集锦
  7. 雷电3接口能干嘛_acasis阿卡西斯推出首款雷电3接口WIFI6网卡:内置Intel AX200
  8. android布局的属性,android
  9. linux的硬件系统管理,Linux 系统硬件管理的基础知识(四)
  10. 颜宁问4对科研夫妻:男女搭配,如何不累?