免费注册 查看新帖 |

Chinaunix

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

如何获得oracle的字段进行删除 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-10-10 17:17 |只看该作者 |倒序浏览
oracle的某个字段存放着文件的路径名,现在想通过对oracle的查询,将符合条件的文件取出来然后删除
我构想的思路如下,把查出来的结果写到某个文件,然后再对文件进行遍历删除。
不知道各位有没有更好的法子?

[ 本帖最后由 locallocal 于 2007-10-10 17:25 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2007-10-10 17:24 |只看该作者
原帖由 locallocal 于 2007-10-10 17:17 发表
现在想通过对oracle的查询,将符合条件的文件取出来,然后删除
我构想的思路如下,把查出来的结果写到某个文件,然后再对文件进行遍历删除。
不知道各位有没有更好的法子?

直接

echo ‘
select "rm -f " || filename
   from tabx
   where ...
;' | sqlplus -S user/passwd@sid | sh

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
3 [报告]
发表于 2007-10-11 12:10 |只看该作者
原帖由 ivhb 于 2007-10-10 17:24 发表

直接

echo ‘
select "rm -f " || filename
   from tabx
   where ...
;' | sqlplus -S user/passwd@sid | sh


这个方法很好,但是,为何最后加个 |sh, 我不加的话,好像也行。

[ 本帖最后由 rdcwayx 于 2007-10-11 12:42 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2007-10-11 15:00 |只看该作者
#!/bin/sh
if [ $# -ne 1 ]
then
    echo "program need two arguments"
    exit 1
fi
deldate=$1;
echo "do you really want to delete the image before $deldate???[y...n]"
read ANS
if [ "$ANS" = "Y" ] || [ "$ANS" = "y" ]
then
    echo 'select "rm -f"||path from image,lastbacktm where insertdate < $deldate and backtime > $deldate;' | sqlplus -S system/oracle@sid | sh
else
    echo "not delete any images,bye"
fi
这个似乎执行的时候会报错,很多的command找不到。。。不知道原因在哪?

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
5 [报告]
发表于 2007-10-11 15:06 |只看该作者
#!/bin/sh
if [ $# -ne 1 ]                #这里应该是[ $# -lt 2 ]吧,这样才符合你下面的描述
then
    echo "program need two arguments"
    exit 1
fi
deldate=$1;
echo "do you really want to delete the image before $deldate???[y...n]"
read ANS
if [ "$ANS" = "Y" ] || [ "$ANS" = "y" ]          #这个应该是[ "$ANS" = "Y" -o "$ANS" = "y" ]
then
    echo 'select "rm -f"||path from image,lastbacktm where insertdate < $deldate and backtime > $deldate;' | sqlplus -S system/oracle@sid | sh
else
    echo "not delete any images,bye"
fi

论坛徽章:
0
6 [报告]
发表于 2007-10-11 15:23 |只看该作者
'select "rm -f"||path
好像是这里出现的问题,说这个||不是期待的语法
楼上说的那两个地方都正常过去,反而是那个处理文件的地方的语句无法正常执行。。。。

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
7 [报告]
发表于 2007-10-11 15:30 |只看该作者
先把SQL执行通过吧
select
    "rm -f"||path
from image,lastbacktm
where insertdate < $deldate and backtime > $deldate;
这个把变量替换后拿到PLSQL里面能执行么?

论坛徽章:
0
8 [报告]
发表于 2007-10-11 15:47 |只看该作者
echo ‘
select "rm -f " || filename
   from tabx
   where ...
;' | sqlplus -S user/passwd@sid | sh
应该不能,这个是参照了ivhb 的。。。。
关键想把符合时间段搜索出来的path字段的内容(也就是文件的绝对路径进行批量删除)

[ 本帖最后由 locallocal 于 2007-10-11 15:52 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP