SQL Decoration

Seata’s isolation level defaults to read uncommitted. In this mode, the SQL decoration usage of select statements in this article table is supported. Using for update proxy can make Seata achieve read committed. In this mode, the usage of select statements can only be partially supported.

DML Statement Support

| Type | SQL Example | Supported or not | | :—————- | :—————————————————————————— | :——————————————————————————————————- | —- | | AND & OR | UPDATE … WHERE col_name1=expr1 AND col_name2= expr2 | Yes | | LIKE | UPDATE ... WHERE col_name1 LIKE 'NE' | Yes | | Wildcard | UPDATE ... WHERE col_name1 LIKE 'NE%' | Yes | | BETWEEN | UPDATE ... WHERE col_name1 BETWEEN expr1 AND expr2 | Yes | | ON DUPLICATE | INSERT INTO tb1_name [(col_name,...)]VALUES (\{expr | DEFAULT},...),(...),...[ ON DUPLICATE KEY UPDATE col_name=expr, ... ] | Yes |

Select Statement Support

TypeSQL ExampleRead UncommittedRead Committed
AND & ORSELECT FROM tb1_name WHERE col_name1=expr1 AND col_name2= expr2YesYes
ORDER BYSELECT col_name1, col_name2 FROM tb1_name ORDER BY col_name1YesYes
GROUP BYSELECT col_name1, col_name2 FROM tb1_name GROUP BY col_name1YesYes
LIKESELECT col_name1, col_name2 FROM tb1_name WHERE col_name1 LIKE ‘NE’YesYes
WildcardsSELECT col_name1, col_name2 FROM tb1_name WHERE col_name1 LIKE ‘NE%’YesYes
EXISTSSELECT col_name1, col_name2 FROM tb1_name WHERE EXISTS (expr1)YesYes
INSELECT col_name1, col_name2 FROM tb1_name WHERE col_name1 IN (expr1, expr2,…)YesYes
BETWEENSELECT col_name1, col_name2 FROM tb1_name WHERE col_name1 BETWEEN expr1 AND expr2YesYes
ON DUPLICATEINSERT INTO tb1_name [(col_name,…)]VALUES ({expr | DEFAULT},…),(…),…[ ON DUPLICATE KEY UPDATE col_name=expr, … ]YesYes
ALIASESSELECT t1. col_name1, t2.col_name2 FROM tb1_name AS t1, tb2_name AS t2 WHERE t1. col_name=expr AND t2. col_name=exprYesYes
TOPSELECT TOP 2 FROM tb1_nameYesYes
LIMITSELECT col_name1, col_name2 FROM tb1_name LIMIT 5YesYes
JOININNER JOINLEFT JOINRIGHT JOINFULL JOINSELECT col_name1, col_name2 FROM tb1_name JOIN tb2_name>ON tb1_name. col_name1= tb2_name. col_name1YesNo
UNIONUNION ALLSELECT INTOSELECT col_name1, col_name2 FROM tb1_name UNION SELECT col_name1, col_name2 FROM tb2_nameYesNo