为什么sqplus变量在尝试在它们之后使用句点时表现得很有趣?
SQL> set define on
SQL> accept goo char prompt 'goo: ';
goo: mygoo
SQL> select '&goo' from dual;
old 1: select '&goo' from dual
new 1: select 'mygoo' from dual
MYGO
-----
mygoo
SQL> select '&goo something' from dual;
old 1: select '&goo something' from dual
new 1: select 'mygoo something' from dual
MYGOOSOMETHING
---------------
mygoo something
SQL> select '&goo.something' from dual;
old 1: select '&goo.something' from dual
new 1: select 'mygoosomething' from dual
MYGOOSOMETHIN
--------------
mygoosomething
SQL> select '&goo..something' from dual;
old 1: select '&goo..something' from dual
new 1: select 'mygoo.something' from dual
MYGOO.SOMETHIN
---------------
mygoo.something
为什么我要在月经时加倍呢?有什么更好的办法吗?
发布于 2019-09-06 13:36:11
这一点都不好笑,但预期的默认行为。
SET CONCAT
字符是句点(除非您将它设置为其他字符)。如果要在替换变量之后添加句点,则必须使用两个连续的句点。
如果您将串接字符设置为例如#
,则周期正常工作。
SQL> set concat '#'
SQL> select '&goo.' from dual;
old 1: select '&goo.' from dual
new 1: select 'mygoo.' from dual
'MYGOO
------
mygoo.
如果你把它调回一个句号,它又表现得很有趣:
SQL> set concat '.'
SQL> select '&goo.' from dual;
old 1: select '&goo.' from dual
new 1: select 'mygoo' from dual
'MYGO
-----
mygoo
SQL> select '&goo..' from dual;
old 1: select '&goo..' from dual
new 1: select 'mygoo.' from dual
'MYGOO
------
mygoo.
最后,回到#
,它的行为也很有趣,您必须使用其中的两个:
SQL> set concat '#'
SQL> select '&goo#' from dual;
old 1: select '&goo#' from dual
new 1: select 'mygoo' from dual
'MYGO
-----
mygoo
SQL> select '&goo##' from dual;
old 1: select '&goo##' from dual
new 1: select 'mygoo#' from dual
'MYGOO
------
mygoo#
SQL>
https://stackoverflow.com/questions/57828699
复制