类型转换函数¶
本文介绍 NebulaGraph 支持的类型转换函数。
toBoolean()¶
toBoolean() 将字符串转换为布尔。
语法:toBoolean(<value>)
- 返回类型:bool。
示例:
nebula> UNWIND [true, false, 'true', 'false', NULL] AS b \
RETURN toBoolean(b) AS b;
+----------+
| b |
+----------+
| true |
| false |
| true |
| false |
| __NULL__ |
+----------+
toFloat()¶
toFloat() 将整数或字符串转换为浮点数。
语法:toFloat(<value>)
- 返回类型:float。
示例:
nebula> RETURN toFloat(1), toFloat('1.3'), toFloat('1e3'), toFloat('not a number');
+------------+----------------+----------------+-------------------------+
| toFloat(1) | toFloat("1.3") | toFloat("1e3") | toFloat("not a number") |
+------------+----------------+----------------+-------------------------+
| 1.0 | 1.3 | 1000.0 | __NULL__ |
+------------+----------------+----------------+-------------------------+
toString()¶
toString() 将任意非复合数据类型数据转换为字符串类型。
语法:toString(<value>)
- 返回类型:string。
示例:
nebula> RETURN toString(9669) AS int2str, toString(null) AS null2str;
+---------+----------+
| int2str | null2str |
+---------+----------+
| "9669" | __NULL__ |
+---------+----------+
toInteger()¶
toInteger() 将浮点或字符串转换为整数。
语法:toInteger(<value>)
- 返回类型:int。
示例:
nebula> RETURN toInteger(1), toInteger('1'), toInteger('1e3'), toInteger('not a number');
+--------------+----------------+------------------+---------------------------+
| toInteger(1) | toInteger("1") | toInteger("1e3") | toInteger("not a number") |
+--------------+----------------+------------------+---------------------------+
| 1 | 1 | 1000 | __NULL__ |
+--------------+----------------+------------------+---------------------------+
toSet()¶
toSet() 将列表或集合转换为集合。
语法:toSet(<value>)
- 返回类型:set。
示例:
nebula> RETURN toSet(list[1,2,3,1,2]) AS list2set;
+-----------+
| list2set |
+-----------+
| {3, 1, 2} |
+-----------+
hash()¶
hash() 返回参数的哈希值。其参数可以是数字、字符串、列表、布尔值、NULL 等类型的值,或者计算结果为这些类型的表达式。
hash()
函数采用 MurmurHash2 算法,种子(seed)为0xc70f6907UL
。用户可以在 MurmurHash2.h
中查看其源代码。
在 Java 中的调用方式如下:
MurmurHash2.hash64("to_be_hashed".getBytes(),"to_be_hashed".getBytes().length, 0xc70f6907)
语法:hash(<string>)
- 返回类型:int。
示例:
nebula> RETURN hash("abcde");
+--------------------+
| hash("abcde") |
+--------------------+
| 811036730794841393 |
+--------------------+
nebula> YIELD hash([1,2,3]);
+----------------+
| hash([1,2,3]) |
+----------------+
| 11093822460243 |
+----------------+
nebula> YIELD hash(NULL);
+------------+
| hash(NULL) |
+------------+
| -1 |
+------------+
nebula> YIELD hash(toLower("HELLO NEBULA"));
+-------------------------------+
| hash(toLower("HELLO NEBULA")) |
+-------------------------------+
| -8481157362655072082 |
+-------------------------------+
最后更新:
August 7, 2023