【深入理解TcaplusDB技術】非同步掃描資料示例程式碼——[List表]
阿新 • • 發佈:2022-04-18
參見章節: 準備工作。
示例程式碼
示例程式碼
import com.tencent.tcaplus.client.Client;
import com.tencent.tcaplus.client.ClientFactory;
import com.tencent.tcaplus.client.ListTableTraverser;
import com.tencent.tcaplus.client.Record;
import com.tencent.tcaplus.client.Request;
import com.tencent.tcaplus.client.Response;
import com.tencent.tdr.tcaplus_protocol_cs.TcaplusProtocolCsConstants;
import java.util.ArrayList;
import java.util.List;
public class Example {
public static void main(String[] arguments) {
// 1. 準備環境資訊
// 1.1. 目錄服務地址列表
List<String> dirList = new ArrayList<String>();
dirList.add("tcp://x.x.x.x:9999");
dirList.add("tcp://y.y.y.y:9999");
// 1.2. 業務ID
int appId = 1;
// 1.3. 業務密碼
String appPassword = "****************";
// 1.4. 表格組ID
int tableGroupId = 1;
// 1.5. 表格名稱
String tableName = "test";
// 2. 建立客戶端
Client client = ClientFactory.createClient(appId, tableGroupId, appPassword, dirList);
try {
// 3. 構造根據部分Key欄位值讀取資料的請求
// 3.1. 獲取請求物件。為了提升SDK效能,Request物件是複用的
Request request = client.acquireRequest();
// 3.2. 建立1個掃描器
ListTableTraverser traverser = client.getListTableTraverser();
// 3.3. 設定目標表名。注意:目標表必須為List表
traverser.setTableName(tableName);
// 3.4. 新增需要讀取的Value欄位
traverser.addFieldName("typeid");
traverser.addFieldName("Data");
traverser.addFieldName("uname");
CountDownLatch latch = new CountDownLatch(1);
// 4. 非同步啟動掃描器,並指定返回結果處理器
traverser.startAsync(new Future() {