3

我正在尝试将用 c-shell 脚本编写的脚本重写为使用 sql plus 命令从 oracle 数据库获取信息,但我用 mysql 替换它,我想用 mysql 语法替换所有 sqlplus 语法。我要求所有 c-shell 大师向我解释这个命令的含义

 set SQLPLUS=${ORACLE_HOME}/bin/sqlplus 

 set REPORT=${MYBD_HOME}/Scripts/report.sql

所以在某处我使用以下命令调用 sql plus 命令

 ${SQLPLUS} ${MYDBUSER} @ &{REPORT}

我可以说我理解右手值的含义({ORACLE_HOME}/bin/sqlplus)是我的 sqplus 命令所在的路径,因此我需要它来调用命令和 {REPORT=$(MYBD_HOME} /Scripts.report.sql) 是通过调用 sqplus 命令运行的我的 sql 脚本所在的路径是否正确?

我不明白 set 命令将其初始化为什么。SQLPLUS 是一个变量,所以当我尝试将其放入我的 .csh 脚本时,我不必键入路径?

如果是这样,那么在 mysql 数据库上运行此脚本所需要做的只是将 SQLPLUS(可能将其更改为 MYSQL)指向我的 msql exec 正确的路径

  set MYSQL=${MYSQL_HOME}/bin/mysql

然后只需调用 mysql 并运行 sql 语句

  ${MYSQL}${MYDBUSER}@${REPORT}

这是我需要做的 ro tun 相同的 .tsch 脚本以从 mysql 表中获取数据吗?

4

1 回答 1

2

你需要这样的东西:

${MYSQL} -u $username -p$password -D $database < ${REPORT}

(用户名和密码传递给 mysql 可执行文件的方式与传递给 SQLPlus 的方式不同。您需要从 ${MYDBUSER} 中解析出用户名和密码。可能包含诸如“ scott/tiger”之类的字符串。 mysql 命令行客户端上的等效项是“ -u scott -ptiger -D scott”。

@(at 符号)是 SQLPlus 的东西;它告诉 SQLPLus 从指定的文件名读取输入。mysql 中的等价物是source命令,例如

${MYSQL} -u $username -p$password <_EOD!
use $database 
source ${REPORT}
_EOD!

此外,您的report.sql文件可能包含spool其他 SQLPLus 特定命令。mysql 命令行客户端并不像 SQLPlus 那样强大的报告工具。


附录:

问:阀芯具体有什么作用?

SQLPlusspool命令将输出定向到文件。它经常用于从 SQLPLus 会话创建日志文件,也可用于创建报告文件。

set trimspool on
spool /tmp/file.lis
select 'foo' as foo from dual;
spool off

问:为什么我不能将用户名和密码设置为变量并使用它?

您可以设置一个变量,发送到操作系统的命令行的最终结果将是相同的。

set MYDBUSER="-u username -ppassword -D database"
${MYSQL} ${MYDBUSER} <${REPORT}

问:好像 mysql 比 sqlplus 更冗长。

mysql 命令行客户端采用 unix 样式的选项。这些是等价的:

mysql -u myusername -pmypassword -D mydatabase
mysql --user=myusername --password=mypassword --database=mydatabase
于 2012-06-20T21:16:05.550 回答