全文索引
在 seekdb 中,全文索引可以应用于 CHAR、VARCHAR 和 TEXT 类型的列。此外,seekdb 允许在主表上建立多个全文索引,并且对于同一列也可以建立多个全文索引。
非分区表和分区表上有无主键都可以创建全文索引,创建全文索引限制如下:
- 全文索引仅支持应用于
CHAR、VARCHAR和TEXT类型的列。 - 当前版本只支持创建局部(
LOCAL)全文索引。 - 创建全文索引时不可以指定
UNIQUE关键字。 - 如果要创建涉及多列的全文索引,则必须确保这些列具有相同的字符集。
通过使用这些语法和规则,seekdb 的全文索引功能提供了对文本数据的高效搜索和搜索能力。
DML 操作
对于已创建包含全文索引的表,支持 INSERT INTO ON DUPLICATE KEY、REPLACE INTO、多表的更新/删除、以及可更新视图等复杂 DML 操作。
示例如下:
-
INSERT INTO ON DUPLICATE KEY:
INSERT INTO articles VALUES ('seekdb', 'Fulltext search index support insert into on duplicate key')
ON DUPLICATE KEY UPDATE title = 'seekdb'; -
REPLACE INTO:
REPLACE INTO articles(title, context) VALUES ('seekdb', 'Fulltext search index support replace'); -
多表的更新/删除。
-
创建表
tbl1。CREATE TABLE tbl1 (a int PRIMARY KEY, b text, FULLTEXT INDEX(b)); -
创建表
tbl2。CREATE TABLE tbl2 (a int PRIMARY KEY, b text); -
多个表的更新(
UPDATE)语句。UPDATE tbl1 JOIN tbl2 ON tbl1.a = tbl2.a
SET tbl1.b = 'dddd', tbl2.b = 'eeee';UPDATE tbl1 JOIN tbl2 ON tbl1.a = tbl2.a SET tbl1.b = 'dddd';UPDATE tbl1 JOIN tbl2 ON tbl1.a = tbl2.a SET tbl2.b = tbl1.b; -
多个表的删除(
DELETE
-