8

我目前尝试在 Oracle DB 上执行以下查询

select tzname || ' (UTC'|| tz_offset(tzname) || ')' from v$timezone_names

它似乎不是很复杂。只是时区的名称和大括号中的 UTC 偏移量。但是当我在 Windows 上使用 PL/SQL Developer 执行查询时,它总是会吃掉最后一个大括号。

所以我去了 sqlplus 并在那里执行它,现在我得到了我的最后一个大括号,但在最后一个大括号之前还有一个额外的空格作为额外的好东西。

我已经尝试过嵌套to_char()trim()但没有任何变化。我也在不同的数据库上尝试过,但它总是一样的。

tz_offset有人知道字符串连接是否有问题吗?

4

3 回答 3

7

发出以下查询:

select dump(tz_offset(tzname)) from v$timezone_names;

你会得到这样的结果:

Typ=1 Len=7: 43,48,49,58,48,48,0
Typ=1 Len=7: 43,48,49,58,48,48,0
Typ=1 Len=7: 43,48,49,58,48,48,0
Typ=1 Len=7: 43,48,49,58,48,48,0
Typ=1 Len=7: 43,48,49,58,48,48,0
Typ=1 Len=7: 43,48,49,58,48,48,0
...

这表明tz_offset()返回以空值结尾的字符串(可能是一个错误)。因此,对于您的查询,Oracle 正在返回

"Africa/Algiers (UTC+01:00\0)" // Note \0 -> null character
"Africa/Cairo (UTC+03:00\0)" // Note \0 -> null character
...

考虑到这一点,我猜 PL/SQL Developer 将 \0 解释为字符串结尾(可能是另一个错误,SQL 字符串不是以空值结尾的),因此它不会打扰编写字符串的其余部分,所以你输了尾括号。SQL*PLus 选择打印一个空格而不是那个 null,然后继续处理字符串的其余部分,打印右大括号。

作为一种解决方法,您可以替换tz_offset(...)replace(tz_offset(...), chr(0)). 这将从tz_offset(...)返回的任何内容中删除空值。

于 2011-06-01T13:34:52.353 回答
1

它适用于子字符串,但这并不能真正回答你为什么会发生的问题:-):

选择 tzname || ' (UTC'|| substr(tz_offset(tzname),1,6) || ')' 来自 v$timezone_names;

于 2011-06-01T13:18:57.723 回答
0

我正在创建一个 JSON ajax 资源,它返回需要包含时区偏移量的时间戳......那个尾随控制字符真的很烦我,如果关闭,我会按如下方式修剪:

regexp_replace(tz_offset('加拿大/山区'),'[[:cntrl:]]','')

于 2016-05-04T00:24:54.977 回答