日本熟妇hd丰满老熟妇,中文字幕一区二区三区在线不卡 ,亚洲成片在线观看,免费女同在线一区二区

通過 Go 客戶端連接數據庫使用示例

本章節將介紹如何使用 Go 客戶端以及具體的接口。

連接 OceanBase 數據庫

您可使用 Go 客戶端登錄 OceanBase,具體方法可參考 通過 Go 客戶端連接 OceanBase 數據庫

執行 CREATE TABLE 指令創建表。

CREATE TABLE IF NOT EXISTS `test_varchar_table_00` (
 `c1` varchar(20) NOT NULL,
 `c2` varchar(20) DEFAULT NULL,
 `c3` varchar(20) DEFAULT NULL,
 PRIMARY KEY (`c1`)
);

insert 接口

您可使用該接口插入一行記錄,但如果主鍵沖突(即行已存在),則插入失敗。

示例如下:

long insert(String tableName, Object rowkey, String[] columns, Object[] values);
long insert(String tableName, Object[] rowkeys, String[] columns, Object[] values);

// 樣例,rowkey 對應表中的 primary key
client.insert( "testHash", 
 new Object[] { 1L, "partition".getBytes(), timeStamp },
 new String[] { "V" }, 
 new Object[] { "value".getBytes() }
);

參數說明:

  • tableName:表名

  • rowkey:主鍵值

  • columns:插入的列名(一列或多列)

  • values:插入的列值

  • long:返回值,表示具體的插入數量(1行)

get 接口

您可使用該接口取回一行記錄,如果行存在,則取回行,否則返回 empty。

示例如下:

Map<String, Object> get(String tableName, Object rowkey, String[] columns);
Map<String, Object> get(String tableName, Object[] rowkeys, String[] columns);

// rowkey 即 primary key
Map<String, Object> res = client.get("testHash",
 new Object[] { 1L, "partition".getBytes(), timestamp }, 
 new String[] { "K", "Q", "T","V" }
);

// 返回的結果 value 是 object,直接強轉一下就行 例如 Long k = (Long) res.get("K");

參數說明:

  • tableName:表名

  • rowkey:主鍵值

  • columns:獲取的列名(一行或多列)

  • Map<String, Object>:返回值,成功返回所選列結果,失敗返回 empty

delete 接口

您可使用該接口刪除一行記錄,如果該行不存在,返回 affectrows = 0,否則返回具體刪除的行數量(1)。

示例如下:

long delete(String tableName, Object rowkey);
long delete(String tableName, Object[] rowkeys);

// 樣例,rowkey 對應表中的 primary key
client.delete("testHash", new Object[] { 1L, "partition".getBytes(), timeStamp });

// 返回結果表示 affectrows, 這里返回 1L

參數說明:

  • tableName:表名

  • rowkey:需要刪除的主鍵記錄

  • long:返回值,表示具體刪除的行數量(1行)

update 接口

您可使用該接口更新一行記錄,如果目標行不存在,返回 affectrows = 0,否則返回具體更新的行數量(1)。

示例如下:

long update(String tableName, Object rowkey, String[] columns, Object[] values);
long update(String tableName, Object[] rowkeys, String[] columns, Object[] values);

// 樣例,rowkey 為表的 primary_key
client.update("testHash",
 new Object[] { 1L, "partition".getBytes(), timeStamp }, 
 new String[] { "V" },
 new Object[] { "value1L".getBytes() }
);

// 返回結果表示 affectrows, 這里返回 1L

參數說明:

  • tableName:表名

  • rowkey:更新的主鍵名

  • columns:更新的目標列(一列或多列)

  • values:需要更新的列值(一列或多列)

  • long 返回值,表示具體更新的行數量(1行)

replace 接口

您可使用該接口替換一行記錄,使用該接口會出現以下三種情況:

  • 目標行不存在,則插入記錄。

  • 目標行已存在(即主鍵沖突),則刪除原紀錄,然后再插入這行記錄。

  • 如果有唯一索引沖突,則刪除所有引起沖突的行,然后再插入這行記錄。

示例如下:

long replace(String tableName, Object rowkey, String[] columns, Object[] values);
long replace(String tableName, Object[] rowkeys, String[] columns, Object[] values);

// 樣例,rowkey 為表的 primary_key
client.replace("testHash",
 new Object[] { 1L, "partition".getBytes(), timeStamp }, 
 new String[] { "V" },
 new Object[] { "value1L".getBytes() }
);

// 返回結果表示 affectrows, 這里返回 1L

參數說明:

  • tableName:表名

  • rowkey:主鍵名

  • columns:替換目標的列名(一列或多列)

  • values:替換目標的列值 (一列或多列)

  • long:返回值,表示具體 replace 的行數量(1行)

insertOrupdate 接口

您可使用該接口插入或修改一行記錄,使用該接口會出現以下三種情況:

  • 目標行不存在,則插入記錄。

  • 目標行已存在(即主鍵沖突),則更新這行記錄。

  • 如果插入有唯一索引沖突,則也執行更新操作。

示例如下:

long insertOrUpdate(String tableName, Object rowkey, String[] columns, Object[] values);
long insertOrUpdate(String tableName, Object[] rowkeys, String[] columns, Object[] values);

// 樣例,rowkey 為表的 primary_key
client.insertOrUpdate("testHash",
 new Object[] { 1L, "partition".getBytes(), timestamp }, 
 new String[] { "V" },
 new Object[] { "bb".getBytes() }
);

// 返回結果表示 affectrows,這里返回 1L

參數說明:

  • tableName:表名

  • rowkey:主鍵名

  • columns:操作的目標列名(一列或多列)

  • values:目標列值(一列或多列)

  • long:返回值,表示具體 insert_or_update 的行數量(1行)

increment 接口

您可使用該接口把指定列的值原子地增加某個增量值(可以為負數),使用該接口會出現以下三種情況:

  • 計算結果溢出列類型的值域,報錯。

  • 目標行不存在,則插入,把增量值設置為初值(即等價于原值為 0)。

  • 目標行存在,但是指定列的值為 NULL,把增量值設置為初值(即等價于原值為 0)。

示例如下:

Map<String, Object> increment(String tableName, Object rowkey, String[] columns,Object[] values, boolean withResult);

Map<String, Object> increment(String tableName, Object[] rowkeys, String[] columns, Object[] values, boolean withResult);

// 樣例,rowkey 為表的 primary_key,默認為 null, 所以最后結果為 c2=1,c3=2
Client.increment("test_increment", 
"test_null", 
 new String[] { "c2", "c3" }, 
 new Object[] { 1, 2 }, true );

參數說明:

  • tableName:表名

  • rowkey:主鍵值

  • columns:自增目標列名(一列或多列)

  • values:目標列自增值 (一列或多列)

  • withResult:判斷是否返回自增結果集

  • Map<String, Object>:返回值,如果 withResult = false ,返回結果為 Map.empty。

append 接口

您可使用該接口把指定列的值原子地追加某個串,使用該接口會出現以下三種情況:

  • 計算結果溢出列類型的值域,報錯。

  • 目標行不存在,則插入,把增量值設置為初值(即等價于原值為空串)。

  • 目標行存在,但是指定列的值為 NULL,把增量值設置為初值(即等價于原值為空串)。

示例如下:

Map<String, Object> append(String tableName, Object rowkey, String[] columns, Object[] values,boolean withResult);

Map<String, Object> append(String tableName, Object[] rowkeys, String[] columns, Object[] values, boolean withResult);

// 先插入一條數據 c2 = {1} , c3 = {"P"}
client.insert("test_append", "test_normal", new String[] { "c2", "c3" }, new Object[] { new byte[] { 1 }, "P" });
// append 以后, c2 = {1, 2}, c3 = {"PY"}
Map<String, Object> res = client.append("test_append", "test_normal", new String[] { "c2", "c3" }, new Object[] { new byte[] { 2 }, "Y" }, true);

參數說明:

  • tableName:表名

  • rowkey:主鍵值

  • columns:增加串的目標列名(一列或多列)

  • values:目標列增加串值 (一列或多列)

  • withResult:判斷是否返回增加串結果集

  • Map<String, Object>:返回值,如果 withResult = false ,返回結果為 Map.empty。

scan 接口

您可使用該接口進行范圍查找,支持根據主鍵或主鍵的前綴進行范圍掃描,也可以不指定主鍵,根據索引或者索引前綴范圍進行掃描查詢,接口支持多 range 掃描和逆序掃描。

示例如下:

// 樣例
TableQuery tableQuery = client.query("table_name"); // 根據表名,創建掃描對象
re"sultSet = tableQuery.select("column2").primaryIndex().addScanRange("min1", "max1).addScanRange("min2", "max2").setBatchSize(batch_size).execute();

while(resultSet.next()) {
 Map<String, Object> value = resultSet.getRow();
}

參數說明:

  • table_name:待掃描的表名。

  • primaryIndex:設定根據主鍵值掃描。

  • column2:設定獲取結果的列,例如一張表有 4 列,column1~column4,而只需要返回 column2 這一列的數據。

  • addScanRange:添加查找范圍,其中 min,max 為范圍的左右區間值。

  • batch_size:在滿足掃描條件的行記錄中,每一批需要返回的數量。

batch 接口

您可使用該接口批量執行多種操作組合。

示例如下:

TableBatchOps batchOps = client.batch("test_varchar_table");
batchOps.insert("foo", new String[] { "c2" }, new String[] { "bar" });
batchOps.get("foo", new String[] { "c2" });
batchOps.delete("foo");

List<Object> results = batchOps.execute();
// 上面返回結果的list, insert 返回 affectedRows, get 返回 map 結果,delete 返回 affectedRows

參數說明:

  • TableBatchOps:操作對象,通過 ObTableClient 對象創建,如上述的 client.batch(table_name)。

  • List<Object>:返回值,包含所有操作的結果集合,如上述的 insert、get、delete。