全文搜索
在语句中,使用WHERE
子句指定字符串的搜索条件。
请确保已经部署全文索引。详情请参见部署全文索引和。
使用全文索引前,请确认已经了解全文索引的使用限制。
SHOW FULLTEXT INDEXES;
DROP FULLTEXT INDEX <index_name>;
PREFIX(schema_name.prop_name, prefix_string, row_limit, timeout)
WILDCARD(schema_name.prop_name, wildcard_string, row_limit, timeout)
REGEXP(schema_name.prop_name, regexp_string, row_limit, timeout)
-
fuzziness
:可选项。允许匹配的最大编辑距离。默认值为AUTO
。查看其他可选值和更多信息,请参见。operator
:可选项。解释文本的布尔逻辑。可选值为OR
(默认)和and
。
row_limit
:可选项。指定要返回的行数。默认值为100
。
//创建图空间。
nebula> CREATE SPACE basketballplayer (partition_num=3,replica_factor=1, vid_type=fixed_string(30));
//登录文本搜索客户端。
nebula> SIGN IN TEXT SERVICE (127.0.0.1:9200);
//切换图空间。
nebula> USE basketballplayer;
//添加listener到Nebula Graph集群。
nebula> ADD LISTENER ELASTICSEARCH 192.168.8.5:9789;
//创建Tag。
nebula> CREATE TAG player(name string, age int);
//创建原生索引。
nebula> CREATE TAG INDEX name ON player(name(20));
//重建原生索引。
nebula> REBUILD TAG INDEX;
nebula> CREATE FULLTEXT TAG INDEX nebula_index_1 ON player(name);
//重建全文索引。
nebula> REBUILD FULLTEXT INDEX;
//查看全文索引。
nebula> SHOW FULLTEXT INDEXES;
+------------------+-------------+-------------+--------+
| Name | Schema Type | Schema Name | Fields |
+------------------+-------------+-------------+--------+
| "nebula_index_1" | "Tag" | "player" | "name" |
+------------------+-------------+-------------+--------+
//插入测试数据。
nebula> INSERT VERTEX player(name, age) VALUES \
"Russell Westbrook": ("Russell Westbrook", 30), \
"Chris Paul": ("Chris Paul", 33),\
"Boris Diaw": ("Boris Diaw", 36),\
"David West": ("David West", 38),\
"Danny Green": ("Danny Green", 31),\
"Tim Duncan": ("Tim Duncan", 42),\
"James Harden": ("James Harden", 29),\
"Tony Parker": ("Tony Parker", 36),\
"Aron Baynes": ("Aron Baynes", 32),\
"Ben Simmons": ("Ben Simmons", 22),\
"Blake Griffin": ("Blake Griffin", 30);
//测试查询
nebula> LOOKUP ON player WHERE PREFIX(player.name, "B");
+-----------------+
| _vid |
+-----------------+
| "Boris Diaw" |
+-----------------+
| "Ben Simmons" |
+-----------------+
| "Blake Griffin" |
+-----------------+
nebula> LOOKUP ON player WHERE WILDCARD(player.name, "*ri*") YIELD player.name, player.age;
+-----------------+-----------------+-----+
| "Chris Paul" | "Chris Paul" | 33 |
+-----------------+-----------------+-----+
| "Boris Diaw" | "Boris Diaw" | 36 |
+-----------------+-----------------+-----+
| "Blake Griffin" | "Blake Griffin" | 30 |
+-----------------+-----------------+-----+
nebula> LOOKUP ON player WHERE WILDCARD(player.name, "*ri*") | YIELD count(*);
+----------+
| count(*) |
+----------+
| 3 |
+----------+
nebula> LOOKUP ON player WHERE REGEXP(player.name, "R.*") YIELD player.name, player.age;
+---------------------+---------------------+-----+
| _vid | name | age |
+---------------------+---------------------+-----+
| "Russell Westbrook" | "Russell Westbrook" | 30 |
+---------------------+---------------------+-----+
nebula> LOOKUP ON player WHERE REGEXP(player.name, ".*");
+---------------------+
| _vid |
+---------------------+
| "Danny Green" |
+---------------------+
| "David West" |
+---------------------+
| "Russell Westbrook" |
+---------------------+
...
nebula> LOOKUP ON player WHERE FUZZY(player.name, "Tim Dunncan", AUTO, OR) YIELD player.name;
+--------------+--------------+
| _vid | name |
+--------------+--------------+
| "Tim Duncan" | "Tim Duncan" |
+--------------+--------------+
nebula> DROP FULLTEXT INDEX nebula_index_1;