跳到主要内容

CREATE_RULE

CREATE_RULE 过程用于创建自定义改写规则。

语法

PROCEDURE CREATE_RULE (
rule_name VARCHAR(256),
rule_owner_name VARCHAR(128),
pattern LONGTEXT,
replacement LONGTEXT,
enabled VARCHAR(64) DEFAULT 'YES'
);

参数说明

参数描述
rule_name规则名称。
rule_owner_name数据库名。
pattern规则匹配的语句的模板。
replacement指示如何改写与 pattern 匹配的语句的模板。
enabled规则是否生效。

使用说明

改写绑定规则限制如下:

  • 支持的 SQL 语句类型为:SELECTINSERTREPLACEUPDATEDELETEMERGESET
  • 定义的规则模板中“?”跟“:{name}”不能混用。
  • pattern 定义中当使用“:{name}”来充当参数标记时,name 不能重复出现。
  • patternreplacement 不能定义为空。
  • patternreplacement 不支持 Multi Query。
  • rule_name 需要保证 seekdb 内唯一。
  • 规则模板中 patternreplacement 的参数标记个数必须相同。
  • 规则模板中 patternreplacement 的参数表示方式必须相同(都用“?”表示,或者都用“:{name}”表示)。

示例

CALL DBMS_UDR.CREATE_RULE ('rule1','test','select ? from dual','select ? + 1 from dual');
Query OK, 0 rows affected

SELECT 1 FROM DUAL;
+-------+
| ? + 1 |
+-------+
| 2 |
+-------+
1 row in set

SELECT DB_NAME, RULE_NAME, PATTERN, REPLACEMENT, NORMALIZED_PATTERN, STATUS, PATTERN_DIGEST FROM oceanbase.DBA_OB_USER_DEFINED_RULES;
+---------+-----------+--------------------+------------------------+--------------------+--------+---------------------+
| DB_NAME | RULE_NAME | PATTERN | REPLACEMENT | NORMALIZED_PATTERN | STATUS | PATTERN_DIGEST |
+---------+-----------+--------------------+------------------------+--------------------+--------+---------------------+
| test | rule1 | select ? from dual | select ? + 1 from dual | select ? from dual | ENABLE | 2647993221679348756 |
+---------+-----------+--------------------+------------------------+--------------------+--------+---------------------+
1 row in set