在另一博文《Shell脚本实现DB2数据库表导出到文件》中实现了通过脚本实现将DB2数据库导出到文件,需要传入七个参数,最后一个是一个带有空格字符串,所以传入的时候有点问题,会自动识别空格,默认会将空格前的当作第7个参数,以下是传入的参数:

MD duanwf  CDR_CALL_YYYYMMDD /home/duanwf/asiainfo/export/T141015001_20141014.avl & fetch first  rows only

  最后的“fetch first 100000 rows only”为第七个参数,但是识别的时候只获取到fetch,日志如下:

-- :: [Thread-] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - Run Command:   /home/duanwf/workspace/shell2.sh MD duanwf  CDR_CALL_YYYYMMDD /home/duanwf/asiainfo/export/T141015001_20141014.avl & fetch first  rows only
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - execute sql .................
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - Begin to export the data:
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - \n2014//-:: ====================connect to MD=======================
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - \n2014//-:: db2 connect to MD user duanwf
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - \n2014//-:: Succeed connect to MD
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - \n2014//-:: export to /home/duanwf/asiainfo/export/T141015001_20141014.avl of del modified by nochardel codepage= COLDEL& select * from CDR_CALL_YYYYMMDD fetch:

  

  那要怎么处理呢?

之前问了有人说可以用双引号把他引起来,最后结果还是一样,无法拿到,只能获取到

"fetch

  还是会自动在空格前自动断开。

  可以通过$@命令来处理,即将$7换成echo ${@:7},这样将自动识别到的第7个开始,全部获取到作为最后第7个参数,参数获取改为:

#!/bin/bash

DBSCHEMA=$
DBUSER=$
DBPASSWORD=$
TABLENAME=$
FILEPATH=$
DELIMITER=$
EXPORTLIMIT=`echo ${@:}`

  再次运行结果:

-- :: [Thread-] INFO  com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - Export Parameters: MD duanwf  ST_ZGD_SCOPE_RSFR_GR_DM_201409 /home/duanwf/asiainfo/export/M141015003_201409.avl & fetch first  rows only
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - Run Command: /home/duanwf/workspace/shell/db2.sh MD duanwf ST_ZGD_SCOPE_RSFR_GR_DM_201409 /home/duanwf/asiainfo/export/M141015003_201409.avl & fetch first rows only
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - execute sql .................
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - Begin to export the data:
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - \n2014//-:: ====================connect to MD=======================
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - \n2014//-:: db2 connect to MD user duanwf
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - \n2014//-:: Succeed connect to MD
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - \n2014//-:: export to /home/duanwf/asiainfo/export/M141015003_201409.avl of del modified by nochardel codepage= COLDEL& select * from ST_ZGD_SCOPE_RSFR_GR_DM_201409 fetch first rows only:
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - SQL3104N EXPORT 实用程序 正在开始将数据导出至文件
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - "/home/duanwf/asiainfo/export/M141015003_201409.avl"。
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: -
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - SQL3105N Export 实用程序已经完成导出 "" 行。
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: -
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: -
-- :: [Thread-] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData: - 导出的行数:

问题解决!!

<--------------------------------- 我是华丽的分割线 --------------------------------->

 

补充对Shell函数参数的说明:

来源:http://www.w3cschool.cc/linux/linux-shell-func.html

在Shell中,调用函数时可以向其传递参数。在函数体内部,通过 $n 的形式来获取参数的值,例如,$1表示第一个参数,$2表示第二个参数...

带参数的函数示例:

#!/bin/bash
funWithParam(){
echo "The value of the first parameter is $1 !"
echo "The value of the second parameter is $2 !"
echo "The value of the tenth parameter is $10 !"
echo "The value of the tenth parameter is ${10} !"
echo "The value of the eleventh parameter is ${11} !"
echo "The amount of the parameters is $# !"
echo "The string of the parameters is $* !"
}
funWithParam

输出结果:

The value of the first parameter is  !
The value of the second parameter is !
The value of the tenth parameter is !
The value of the tenth parameter is !
The value of the eleventh parameter is !
The amount of the parameters is !
The string of the parameters is !"

注意,$10 不能获取第十个参数,获取第十个参数需要${10}。当n>=10时,需要使用${n}来获取参数。

另外,还有几个特殊字符用来处理参数:

参数处理 说明
$# 传递到脚本的参数个数
$* 以一个单字符串显示所有向脚本传递的参数
$$ 脚本运行的当前进程ID号
$! 后台运行的最后一个进程的ID号
$@ 与$#相同,但是使用时加引号,并在引号中返回每个参数。
$- 显示Shell使用的当前选项,与set命令功能相同。
$? 显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误。
 

Shell脚本传递带有空格的参数的更多相关文章

  1. Shell脚本传递带有空格的参数[摘录自网络]

    参数处理 说明 $# 传递到脚本的参数个数 $* 以一个单字符串显示所有向脚本传递的参数 $$ 脚本运行的当前进程ID号 $! 后台运行的最后一个进程的ID号 $@ 与$#相同,但是使用时加引号,并在 ...

  2. shell脚本传递带有空格的参数的解决方法

    如下例子所示: #!/bin/sh dt= rdms_presql='select * from dm_general_stat where dimcode = "day" and ...

  3. shell函数传递带空格的参数

    shell中的参数以空格为分割符,经常会碰到需要传递带空格的参数,例如传递带空格的文件名. 方法很简单:给参数加双引号. 但是实际效果要看你的函数内容,一种可能的情况是: 其实你真的传递进去了带空格的 ...

  4. JAVA传递带有空格的参数

    String s="b2 + b1"; Process child = Runtime.getRuntime().exec("C:\\eclipse-workspace\ ...

  5. 解决shell脚本参数传递含有空格的问题

    有这样一个py文件,需要传一个字典作为参数: import json import sys def parse_params(data): json_data = json.loads(data[1] ...

  6. Javascript函数中传递带空格的参数

    通常在页面中要让某些内容点击后产 生点击事件(非页面跳转)都会使用onclick,但是这样不适于需要传递参数的情况,于是写成直接调用Javascript函数的方式:<a href=javascr ...

  7. Uncaught SyntaxError : Unexpected token ILLEGAL js传递带空格的参数

    通常在页面中要让某些内容点击后产生点击事件(非页面跳转)都会使用onclick,但是这样不适于需要传递参数的情况,于是写成直接调用JavaScript函数的方式:<a href=javascri ...

  8. Shell脚本中判断输入变量或者参数是否为空的方法

    shell判断一个变量是否为空方法总结 https://www.jb51.net/article/154835.htm 1.判断变量 复制代码代码如下: read -p "input a w ...

  9. postgresql shell脚本传递参数并执行sql脚本并

    参考: https://stackoverflow.com/questions/7389416/postgresql-how-to-pass-parameters-from-command-line ...

随机推荐

  1. Ant Design的Form组件中FormItem名称相同引起的问题

    1.问题描述 在使用Antd组件Form表单的过程中,会出现FormItem同名的情况,此时要特别注意同名引起的表单行为异常问题,主要表现在以下方面: (1)同名表单项的值共享,并且其中一个的值改变, ...

  2. docker swarm搭建tidb踩坑日记

    背景 公司新项目数据量翻了一倍,每天上亿数据量的读写,传统的单库单表已经满足不了目前的需求,得考虑下分布式存储了.那用啥呢,之前有考虑用到mycat,但是一进官网,一股山寨气息扑面而来,技术群进群还收 ...

  3. win10 uwp 使用 Azure DevOps 自动构建

    通过 Azure DevOps 可以做到自动构建程序,覆盖计划.创建.编程.测试.部署.发布.托管.共享等各个环节,适用于大多数的语言.平台. 本文继续使用图床为例告诉大家如何使用 Azure Dev ...

  4. java 内存操作流

    操作内存流的时候(从读取出来,注意一定要把真正的数据用toByteArray或者toCharArray将数据读出来) 之前的文件操作流是以文件的输入输出为主的,当输出的位置变成了内存,那么就称为内存操 ...

  5. HDU 1540 Tunnel Warfare (线段树)

    Tunnel Warfare Problem Description During the War of Resistance Against Japan, tunnel warfare was ca ...

  6. CCPC 2018 吉林 H "LOVERS" (线段树)

    ---恢复内容开始--- 传送门 参考资料: [1]:https://blog.csdn.net/mmk27_word/article/details/89788448 题目描述: The Fool ...

  7. idea运行项目时报错:Error:java无效的源发行版:1.8

    解决办法:project structure中设置 JDK 和language 匹配即可.如图: 另外如果有maven,需要把maven中JDK版本设置成一样的.

  8. C# 使用汇编

    本文告诉大家如何在 C# 里面使用汇编代码 请看 C#嵌入x86汇编--一个GPIO接口的实现 - 云+社区 - 腾讯云 C# inline-asm / 嵌入x86汇编 - 苏璃 - CSDN博客 通 ...

  9. vue-learning:25 - component - 概念-定义-注册-使用-命名

    概念 Vue遵循Web Component规范,提供了自己的组件系统.组件是一段独立的代码,代表页面中某个功能块,拥有自己的数据.JS.样式,以及标签.组件的独立性是指形成自己独立的作用域,不会对其它 ...

  10. Node.js入门-知识整理

    目的:使用Node.js实现文件上传并将上传的文件显示到浏览器中 基本工具:Node.js,在windows下需要下载cygwin64来运行shell命令 文件:服务器模块.请求路由模块.请求处理程序 ...