我想运行dbaccess,并将输出存储到shell变量,我知道有两种方法可以做(i)输出到管道和(ii)卸载到文件。我想使用方法(i)将查询输出存储到shell变量的方法,但随着查询输出我得到不需要的东西(连接到数据库,列标题,断开连接)图像附加,我不想要使用方法(ii)因为我需要将查询输出存储到shell变量而不是文件。请帮我解决
答案 0 :(得分:2)
在某些情况下,不是最好的方法是将 stderr 发送到/dev/null
。
让我们创建一个表来测试它:
[infx1210@tardis ~]$ dbaccess demo -
Database selected.
> CREATE TABLE starc (col1 INT, col2 INT);
Table created.
> INSERT INTO starc VALUES (1,1);
1 row(s) inserted.
> INSERT INTO starc VALUES (2,2);
1 row(s) inserted.
>
Database closed.
[infx1210@tardis ~]$
对于一列和一行,更多,这已经足够了:
[infx1210@tardis ~]$ out_1r1c=`echo "select col1 FROM starc WHERE col1 = 1" | dbaccess demo 2>/dev/null | uniq`
[infx1210@tardis ~]$ echo $out_1r1c
col1 1
[infx1210@tardis ~]$ out_2r1c=`echo "select col1 FROM starc" | dbaccess demo 2>/dev/null | uniq`
[infx1210@tardis ~]$ echo $out_2r1c
col1 1 2
[infx1210@tardis ~]$
对于多列,可能不是最佳选择:
[infx1210@tardis ~]$ out_1r2c=`echo "select * FROM starc WHERE col1 = 1" | dbaccess demo 2>/dev/null | uniq`
[infx1210@tardis ~]$ echo $out_1r2c
col1 col2 1 1
[infx1210@tardis ~]$ out_2r2c=`echo "select * FROM starc" | dbaccess demo 2>/dev/null | uniq`
[infx1210@tardis ~]$ echo $out_2r2c
col1 col2 1 1 2 2
[infx1210@tardis ~]$
跟进问题
对于您正在做的事情,只需将eco
命令上的信息传递给SQL文件脚本并执行它。
例如:
[infx1210@tardis ~]$ echo "CONNECT TO 'sysmaster@infx1210' USER 'starc' USING '${PASSWD}'; SELECT USER FROM sysdual;" | dbaccess -
32412: USING clause unsupported. DB-Access will prompt you for a password.
Error in line 1
Near character position 45
[infx1210@tardis ~]$ finderr 32412
-32412 USING clause unsupported. DB-Access will prompt you for a password.
DB-Access does not support the USING password clause in a CONNECT ...
USER statement when it violates security. For example, do not type a
password on the screen where it can be seen or include it in a command
file that someone other than the user can read. To maintain security,
DB-Access prompts you to enter the password on the screen and uses echo
suppression to hide it from view.
[infx1210@tardis ~]$ echo "CONNECT TO 'sysmaster@infx1210' USER 'starc' USING '${PASSWD}'; SELECT USER FROM sysdual;" > file.sql
[infx1210@tardis ~]$ dbaccess - file.sql 2>> test.log
(expression)
starc
[infx1210@tardis ~]$
我不喜欢这种做法。您应该考虑使用SET SESSION AUTHORIZATION声明。
现在,要让用户使用它,必须授予 DBA 数据库级别权限,并且还需要 SETSESSIONAUTH 访问权限,并且只有持有{{}的用户3}} role可以授予 SETSESSIONAUTH 权限,只有DBSECADM可以为用户授予 DBSECADM 角色。
通常,拥有 $ INFORMXIDR /等的操作系统组的成员是 DBSA ,在这种情况下:
[infx1210@tardis ~]$ ls -ld $INFORMIXDIR/etc
drwxrwxr-x. 5 informix informix 4096 May 18 13:33 /opt/IBM/informix/V12.1/etc
[infx1210@tardis ~]$ grep informix /etc/group
informix:x:501:ricardo
[infx1210@tardis ~]$
因此,除 informix 用户外,只有 ricardo 是 DBSA的成员。让我们坚持使用 informix 简单。
下一步是 informix 的DBSA角色,这是一个特殊的角色,将遍布所有数据库,您不必逐个执行:
[infx1210@tardis ~]$ echo "GRANT DBSECADM TO 'informix'" | dbaccess sysmaster
Database selected.
DBSECADM granted.
Database closed.
[infx1210@tardis ~]$
现在, SETSESSIONAUTH 无法提供给用户本身,所以我们将其提供给 ricardo :
[infx1210@tardis ~]$ echo "GRANT SETSESSIONAUTH ON 'starc' TO 'ricardo'" | dbaccess demo
Database selected.
SETSESSIONAUTH privilege granted.
Database closed.
[infx1210@tardis ~]$
切换到用户 ricardo ,请记住它应具有 DBA 权限,我们现在可以:
[infx1210@tardis ~]$ echo "SET SESSION AUTHORIZATION TO 'starc'; SELECT USER FROM systables WHERE tabid = 1;" | dbaccess demo 2>>/dev/null
(expression)
starc
[infx1210@tardis ~]$
答案 1 :(得分:2)
正如http://forum.cs-cart.com/topic/29828-a-simple-way-to-add-any-content-on-any-place-on-template/中Ricardo Henriques所述,您可以通过重定向标准错误来执行一定数量的操作。
还要考虑answer声明:
OUTPUT TO "/dev/stdout" WITHOUT HEADINGS
SELECT * FROM YourTable WHERE …
或OUTPUT声明:
UNLOAD TO "/dev/stdout"
SELECT * FROM YourTable WHERE …
使用"/dev/stdout"
是一个技巧 - 有时是有用的。您可以在那里指定任何文件名。您可能仍希望重定向错误。请注意,DB-Access在出错后会出错 - 您可以通过在环境中设置DBACCNOIGN=1
来阻止它。
另外,考虑检查我写的UNLOAD因为它在shell脚本上下文中运行而DB-Access没有。它可以追溯到1986年(在dbaccess
之前;在那些日子里,你使用isql
代替了 - 在晚上从isql
开出了DB-Access。当前版本为SQLCMD 90.00(2015-11-08)。它与微软的同名johnny-come-lately程序没有关系 - 除了这个名字。
答案 2 :(得分:0)
我会添加到前面说过的,首先将STDERR输出为null,然后输出grep -v为$ ^。
IE,从数据库中选择当前日期和时间:
$> echo "output to /dev/stdout without headings select first 1 current from systables;" > query.sql
$> FOO=`dbaccess mydb query.sql 2>/dev/null | grep -v "^$"`
$> echo $FOO
2017-07-27 14:25:30.000
$>
您只需确保查询返回一行,仅一列。