VastbaseG100

基于openGauss内核开发的企业级关系型数据库。

Menu

FIELD

功能描述

FIELD函数用于查找特定字符串在给出的若干个字符串序列中的位置。

函数返回值如下所示:

  • 0:代表待查找字符串不在序列中。

  • 非0值:代表字符串在序列的位置,以1为起始。

语法格式

FIELD(str,str1,str2,str3,...)

参数说明

  • str

    待查找字符串。

  • str1,str2,str3,…

    被查找字符串序列,不定长度。

    • 如果所有传入参数是字符串类型,则这些参数按照字符串规则进行比较。如果所有传入参数是number类型则按 number类型进行比较。否则将按浮点数类型比较。
    • 如果 str为 null,则返回 0,因为 null无法和任何值比较。

注意事项

  • 仅Vastbase G100 V2.2 Build 10(Patch No.8)及以后版本支持此功能。

  • 函数的输入参数个数不能少于2,否则会返回如下错误提示:

    ERROR: Incorrect parameter count in the call to native function 'field'
    

示例

示例1:直接调用FIELD函数。

SELECT field(23.17, 3, 23.17899, 23.1777, 23.17);

返回结果为:

field
------
    4
(1 row)

示例2:在insert语句中使用FILED函数。

1、创建表并插入数据。

CREATE TABLE tb_1116624(c1 int, c2 varchar(10), c3 text);
INSERT INTO tb_1116624 VALUES(1, 'test1', 'test4');
INSERT INTO tb_1116624 VALUES(2, 'test2', 'test5');
INSERT INTO tb_1116624 VALUES(3, 'test3', 'test3');
INSERT INTO tb_1116624 VALUES(4, 'test4', 'test8');
INSERT INTO tb_1116624 VALUES(5, 'test5', 'test2');

2、创建另一张表,用于从上张表中抽取数据。

CREATE TABLE test_insert_tb_1116624(c1 int, c2 varchar(10), c3 text);

3、insert语句中使用FIELD函数。

with SELECT_data_1116624 as(
SELECT * from tb_1116624 order by field(c2, 'test3', 'test1'))
insert into test_insert_tb_1116624 SELECT * from SELECT_data_1116624;

4、查看test_insert_tb_1116624表数据。

SELECT * from test_insert_tb_1116624;

返回结果为:

 c1 |  c2   |  c3
----+-------+-------
  2 | test2 | test5
  4 | test4 | test8
  5 | test5 | test2
  3 | test3 | test3
  1 | test1 | test4
(5 rows)

根据结果可知,测试表 test_insert_tb_1116624中插入了经过order by filed排序之后所创建的临时表数据。

5、清理环境

DROP TABLE tb_1116624,test_insert_tb_1116624;