处理查询

openGauss提供了函数和操作符用来操作tsquery类型的查询。

  • tsquery && tsquery

    返回两个给定查询tsquery的与结果。

  • tsquery || tsquery

    返回两个给定查询tsquery的或结果。

  • !! tsquery

    返回给定查询tsquery的非结果。

  • numnode(query tsquery) returns integer

    返回tsquery中的节点数目(词素加操作符),这个函数在检查查询是否有效(返回值大于0),或者只包含停用词(返回值等于0)时,是有用的。例如:

    1. postgres=# SELECT numnode(plainto_tsquery('the any'));
    2. NOTICE: text-search query contains only stop words or doesn't contain lexemes, ignored
    3. CONTEXT: referenced column: numnode
    4. numnode
    5. ---------
    6. 0
    7. postgres=# SELECT numnode('foo & bar'::tsquery);
    8. numnode
    9. ---------
    10. 3
  • querytree(query tsquery) returns text

    返回可用于索引搜索的tsquery部分,该函数对于检测非索引查询是有用的(例如只包含停用词或否定项)。例如:

    1. postgres=# SELECT querytree(to_tsquery('!defined'));
    2. querytree
    3. -----------
    4. T
    5. (1 row)