55

有可能做这样的事情吗?

$ sqlplus -s user/pass "select 1 from dual" 或者
$ echo "select 1 from dual" | sqlplus -s user/pass

我知道我可以放入select 1 from dual一个文件并执行此操作:
$ sqlplus -s user/pass @myFile.sql

但我想知道是否真的有必要创建一个文件只是为了满足 sqlplus

4

5 回答 5

56

请注意,在 Unix/Linux 上,如果您将其直接放在命令行上,任何可以运行“ps -ef”命令的人都可以看到您的用户名/密码。可能是一个大的安全问题(或变成一个大的安全问题)。

我通常建议创建一个文件或使用此处的文档,这样您就可以保护用户名/密码不被 Unix/Linux 中的“ps -ef”命令查看。如果用户名/密码包含在脚本文件或 sql 文件中,您可以使用适当的用户/组读取权限进行保护。然后,您可以在 shell 脚本中将用户/密码保留在文件中,如下所示:

sqlplus -s /nolog <<EOF
connect user/pass
select blah;
quit
EOF
于 2009-10-28T20:30:43.790 回答
44

只要确保在我的 select 语句末尾有一个分号,我就可以执行您的确切查询。(输出是实际的,连接参数已删除。)

echo "select 1 from dual;" | sqlplus -s username/password@host:1521/service 

输出:

         1
----------
         1

请注意,这应该很重要,但这是在 Mac OS X Snow Leopard 和 Oracle 11g 上运行的。

于 2009-10-28T20:12:49.167 回答
30

我的版本

$ sqlplus -s username/password@host:port/service <<< "select 1 from dual;"


         1
----------
         1

编辑:

对于多行,您可以使用它

$ echo -e "select 1 from dual; \n select 2 from dual;" | sqlplus -s username/password@host:port/service


         1
----------
         1


         2
----------
         2
于 2013-12-17T17:22:10.047 回答
9

我假设这是*nix?

使用“这里文档”:

sqlplus -s user/pass <<+EOF
select 1 from dual;
+EOF

编辑:我应该尝试你的第二个例子。它也可以工作(即使在 Windows 中,无滴答声):

$ echo 'select 1 from dual;'|sqlplus -s user/pw

         1
----------
         1


$
于 2009-10-28T20:05:35.620 回答
0

对于 windows 版本,您可以在下面尝试。删除双引号 (")

echo select 1 from dual; | sqlplus -s username/password@service
于 2021-10-14T02:45:29.113 回答