免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2790 | 回复: 7
打印 上一主题 下一主题

帮忙看一下这个怎么转义呢? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-06-20 16:35 |只看该作者 |倒序浏览
##!/bin/bash
LANG=C
export LANG
year_name=`date +%G`
Directory_Name=`date +%m`
File_Name=`date +%Y-%m-%d-%H:%M:%S`

if [ ! -d "$year_name" ];
        then
        mkdir "$year_name"
        cd "$year_name"
        mkdir "$Directory_Name"
        echo "This directory already exists"
        #df -k > "$year_name/$Directory_Name/$File_Name".log
        exit 0
fi
df -k > "$year_name/$Directory_Name/$File_Name".log
        su - oracle -c "export ORACLE_SID=ORACLE;sqlplus /nolog <<!
                connect /as sysdba
                select tablespace_name,sum(bytes)/1024/1024 from dba_data_files group by tablespace_name;
                select a.tablespace_name,total,free,total-free used from (select tablespace_name,sum(bytes)/1024/1024 total from dba_data_files group by tablespace_name)a,(select tablespace_name,sum(bytes)/1024/1024 free from dba_free_space group by tablespace_name)b where a.tablespace_name=b.tablespace_name;
                select * from v$resource_limit;                quit
                !" >> "$year_name/$Directory_Name/$File_Name".log
                sleep 5

        ftp -in 192.168.0.44 << !
        user root root123
        bin
        lcd "$year_name/$Directory_Name/"
        cd /var/www/html/checkdisk/"$year_name/$Directory_Name"
        put $File_Name.log
        bye
        !

帮忙看看带颜色的那句话应该怎么转义呢?"" '' `` \用过了,不知道是不会用还是写法有问题。没有成功。

论坛徽章:
1
巳蛇
日期:2013-10-28 15:55:33
2 [报告]
发表于 2011-06-20 19:20 |只看该作者
select \* from v\$resource_limit;

论坛徽章:
0
3 [报告]
发表于 2011-06-20 20:03 |只看该作者
在一个文件里面是没有解决,不知道楼上的办法是否可行,我明天试一下给你反馈。我写了一SQL文本解决这问题。

论坛徽章:
0
4 [报告]
发表于 2011-06-20 20:08 |只看该作者
2楼,好像还是不行。我我测试过了。

SQL*Plus: Release 10.2.0.1.0 - Production on Mon Jun 20 20:05:55 2011

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

SQL> Connected.
SQL>            select \* from v
                       *
ERROR at line 1:
ORA-00911: invalid character

论坛徽章:
1
巳蛇
日期:2013-10-28 15:55:33
5 [报告]
发表于 2011-06-20 20:23 |只看该作者
那么*不转义试试.

我还没学sql呢.

论坛徽章:
1
巳蛇
日期:2013-10-28 15:55:33
6 [报告]
发表于 2011-06-20 20:27 |只看该作者
select * from v$resource_limit;
需要sql文件中显示成什么样子的?
$resource_limit保持原状还是被解释?
保持原状可以往前面多加些\, 自己测试下把.

论坛徽章:
0
7 [报告]
发表于 2011-06-21 08:38 |只看该作者
select * from v$resource_limit;
我只希望select * from v$resource_limit;被SQL执行而不被shell解析。

论坛徽章:
0
8 [报告]
发表于 2011-06-21 08:43 |只看该作者
6楼
select * from \,v$resource_limit;
不知道是不是你的意思,如果是那是失败的。
SQL> Connected.
SQL>                 select * from \,v
                              *
ERROR at line 1:
ORA-00911: invalid character
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP