forked from oceanbase/obkv-table-client-java
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathGet.java
More file actions
88 lines (75 loc) · 2.83 KB
/
Get.java
File metadata and controls
88 lines (75 loc) · 2.83 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/*-
* #%L
* com.oceanbase:obkv-table-client
* %%
* Copyright (C) 2021 - 2025 OceanBase
* %%
* OBKV Table Client Framework is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
* http://license.coscl.org.cn/MulanPSL2
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
* #L%
*/
package com.alipay.oceanbase.rpc.get;
import com.alipay.oceanbase.rpc.ObTableClient;
import com.alipay.oceanbase.rpc.mutation.ColumnValue;
import com.alipay.oceanbase.rpc.mutation.Row;
import com.alipay.oceanbase.rpc.protocol.payload.impl.execute.ObTableConsistencyLevel;
import com.alipay.oceanbase.rpc.table.api.Table;
import java.util.Map;
public class Get {
private Table client = null;
private String tableName = null;
private Row rowKey = null;
private String[] selectColumns = null;
private String readConsistency = "";
public Get(Table client, String tableName) {
this.client = client;
this.tableName = tableName;
}
public Get setRowKey(Row rowKey) {
this.rowKey = rowKey;
if (null != tableName && ((ObTableClient) client).getRowKeyElement(tableName) == null) {
((ObTableClient) client).addRowKeyElement(tableName, this.rowKey.getColumns());
}
return this;
}
public Get setRowKey(ColumnValue... rowKey) {
this.rowKey = new Row(rowKey);
if (null != tableName && ((ObTableClient) client).getRowKeyElement(tableName) == null) {
((ObTableClient) client).addRowKeyElement(tableName, this.rowKey.getColumns());
}
return this;
}
public Row getRowKey() {
return rowKey;
}
public Get select(String... columns) {
this.selectColumns = columns;
return this;
}
public Get setReadConsistency(String readConsistency) {
this.readConsistency = readConsistency;
return this;
}
public String getReadConsistency() {
return readConsistency;
}
public String[] getSelectColumns() {
return selectColumns;
}
public Map<String, Object> execute() throws Exception {
ObTableConsistencyLevel readConsistency = null;
if (this.readConsistency != null && !this.readConsistency.isEmpty()) {
readConsistency = ObTableConsistencyLevel.getByName(this.readConsistency);
}
if (client == null) {
throw new IllegalArgumentException("client is null");
}
return ((ObTableClient) client).get(tableName, rowKey, selectColumns, readConsistency);
}
}