首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么sqlplus变量在句点上表现得很有趣?

为什么sqlplus变量在句点上表现得很有趣?
EN

Stack Overflow用户
提问于 2019-09-06 21:25:49
回答 1查看 96关注 0票数 0

为什么sqplus变量在尝试在它们之后使用句点时表现得很有趣?

代码语言:javascript
复制
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

为什么我要在月经时加倍呢?有什么更好的办法吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-09-06 21:36:11

这一点都不好笑,但预期的默认行为。

SET CONCAT字符是句点(除非您将它设置为其他字符)。如果要在替换变量之后添加句点,则必须使用两个连续的句点。

如果您将串接字符设置为例如#,则周期正常工作。

代码语言:javascript
复制
SQL> set concat '#'
SQL> select '&goo.' from dual;
old   1: select '&goo.' from dual
new   1: select 'mygoo.' from dual

'MYGOO
------
mygoo.

如果你把它调回一个句号,它又表现得很有趣:

代码语言:javascript
复制
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.

最后,回到#,它的行为也很有趣,您必须使用其中的两个:

代码语言:javascript
复制
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>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57828699

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档