§ Oracle兼容-函数-LENGTH()函数
§ 1. 语法
LENGTH(data)
1
§ 2. 定义和用法
在Oracle中,LENGTH()
函数返回字符串的长度,而在GreatSQL中 LENGTH()
函数返回字符串的字节数。当参数data中字符串的长度为0时,GreatSQL返回值为0,而Oracle返回值为NULL。
针对上述差异,GreatSQL对 LENGTH()
函数做了扩展,以支持类似Oracle中的行为模式。
§ 3. Oracle兼容说明
因为GreatSQL已原生支持 LENGTH()
函数,因此想要在GreatSQL中使用扩展后的 LENGTH()
函数时,需要先执行 SET sql_mode = ORACLE;
激活Oracle兼容模式。
对于个别转义字符如 ‘‘\n’’,因为GreatSQL会将其自动转为特殊字符,因此最后结果是算作1个字符而不是2个字符。
对于表达式比如 LENGTH(''+1)
,目前ORACLE mode下支持数字转字符串,最后结果变成数值字符串的长度,这个动作与Oracle的不一致。
§ 4. 示例
-- 在DEFAULT mode中,在utf8mb4字符集模式下,结果返回17
-- 示例中的每个中文字符占位3个字节,每个ASCII字符占位1个字节
greatsql> SELECT LENGTH( _UTF8MB4 'GreatSQL数据库');
+---------------------------------------+
| LENGTH( _UTF8MB4 'GreatSQL数据库') |
+---------------------------------------+
| 17 |
+---------------------------------------+
-- 先切换到ORACLE mode
greatsql> SET sql_mode = ORACLE;
-- 示例中的每个中文字符和ASCII字符都算作一个字符
greatsql> SELECT LENGTH( _UTF8MB4 'GreatSQL数据库');
+---------------------------------------+
| LENGTH( _UTF8MB4 'GreatSQL数据库') |
+---------------------------------------+
| 11 |
+---------------------------------------+
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
扫码关注微信公众号