1. 程式人生 > 其它 >【深入理解TcaplusDB技術】非同步掃描資料示例程式碼——[List表]

【深入理解TcaplusDB技術】非同步掃描資料示例程式碼——[List表]

本文準備工作

參見章節: 準備工作

示例程式碼

示例程式碼

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() {

               @Override
               public void onResponse(Response response) {
                   // 5. 處理結果
                   if (response.getResult() == 0) {
                       for (Record result : response.getRecordList()) {
                           // TODO 可在此處新增處理資料程式碼
                      }
                  }
                   if (response.isTraverseCompleted()) {
                       latch.countDown();
                  }
              }

          });

           latch.await();