UPSERT
更新時間:
本文介紹更新時空數(shù)據(jù)表的語法。
語法
upsert_statement ::= UPSERT [hint_clause] INTO table_name
'('columns| _l_ts_')'
VALUES '(' values ')'
[ ON DUPLICATE KEY update_column = update_value |IGNORE ]?
columns ::= column_name, columns
values ::= term, values,'(' values ')'
| function_name '(' term ( ',' term )* ')'
update_column ::= column_name
update_value ::= term
hint_clause::=/*+hint_items*/
hint_items::=hint_item(','hint_item)*
hint_item::=identifier('('hint_option(','hint_option)*')')
hint_option::=expression
說明
支持批量寫入,指定需要寫入的相關列,可以在Values關鍵字中確定幾行數(shù)據(jù)。
支持upsert on duplicate key操作,類似check and put操作,要求upsert指定的value值可以確定一行。如果ON DUPLICATE KEY跟隨的是指定的需要更新的列和value(暫時無法做到基于原有key存在性判斷進行對應value更新),如果存在則拋出異常。 如果是ON DUPLICATE KEY IGNORE表示忽略對應的確定的一行是否存在的檢查,直接進行插入。
Lindorm SQL支持標準JDBC的訪問方式,包括正常statement以及preparestatemt方式,但是對于標準JDBC在preparestatemt場景下的標準batch插入數(shù)據(jù)的方式僅在lindorm 2.2.16版本以后支持。
示例
通過以下兩種方式在時空數(shù)據(jù)表中寫入一條數(shù)據(jù)。
方式一
UPSERT INTO dt(id, g, t) VALUES(0,ST_MakePoint(0.0,1.0),1000);
方式二
UPSERT INTO dt(id, g, t) VALUES(0,ST_GeomFromText('POINT (0.0 1.0)'),1000);
在時空數(shù)據(jù)表中批量寫入數(shù)據(jù)。
UPSERT INTO dt (id, g, t) VALUES(1,ST_MakePoint(1.23,2.34),2000),(2,ST_MakePoint(3.45,5.67),3000),(3,ST_MakePoint(4.56,5.67),4000);
文檔內(nèi)容是否對您有幫助?