oracle中双引号(")的特殊用法

原来一直以为双引号只是一个普通的字符,没有任何作用。今天在论坛中看到一篇帖子http://www.itpub.net/842234.html,谈的是oracle中单引号(')与双引号("),才发现错了。

做个简单的总结:
1)一般来说,字符串中的双引号仅仅被当作一个普通字符进行处理。此时,双引号不需要成对出现:
SQL> select 'hh24"小时""mi"分"""ss"秒"' AS RESULT from dual;

RESULT
-------------------------
hh24"小时""mi"分"""ss"秒"

2)当出现在to_char的格式字符串中时,双引号有特殊的作用,就是将非法的格式符包装起来,避免出现ORA-01821: date format not recognized错误。也就是说,去掉双引号和其包含的字符后,剩下的应该是一个合法的格式串。
to_char在处理格式字符串时,会忽略双引号:

SQL> select to_char(sysdate, 'hh24"小时"mi"分"ss"秒"') AS RESULT from dual;

RESULT
--------------
17小时18分58秒

格式串为'hh24"小时"mi"分"ss"秒"';

去掉双引号部分后,剩下的是'hh24miss',是一个合法的格式串。


的确是头一回看到这样使用双引号。长见识了。

不过即使真不知道双引号的这个用法,也可以这样来处理--虽然麻烦一点:

select to_char(sysdate, 'hh24') || '小时' ||
to_char(sysdate, 'mi') || '分' ||
to_char(sysdate, 'ss') || '秒'
AS RESULT
from dual

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9844649/viewspace-580002/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/9844649/viewspace-580002/

你可能感兴趣的:(数据库)