免费注册 查看新帖 |

Chinaunix

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

请教有关向表中插入记录的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2003-07-01 11:15 |只看该作者 |倒序浏览
问题:
   想从表ltitmp2中选出id,id的范围(1-16),如果从表中
选出的id号,不在范围之内,想在表ltitmp2中插入该Id号。
例如:从表中选出的id号为:1,2,3,5,6,。。16
不包含:4,那么就把4号id按要求插入。

大体写了一个,但执行不对,请高手指点。

#!/usr/bin/ksh
for i in 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
do
sql<<EOF
declare @no_1 int
declare id_1 cursor  for
    select id from ltitmp2 where type='A1'
open id_1
fetch id_1 into @no_1
while(@@sqlstatus!=2)
  begin
   if (@no_1!=$i)
    insert into ltitmp2 values($i,"0","A1"
   fetch id_1 into @no_1
  end
close id_1
deallocate cursor id_1
EOF
done

论坛徽章:
0
2 [报告]
发表于 2003-07-01 11:38 |只看该作者

请教有关向表中插入记录的问题

sql里不能用declear

论坛徽章:
0
3 [报告]
发表于 2003-07-01 14:12 |只看该作者

请教有关向表中插入记录的问题

我的sql其实是isql -U -P 脚本

   另外,我的其他例子中用到过declare,使用是正确的。
   (系统是hp unix ,数据库是:sybase )

   感觉还是和shell语言一起使用时,那里语法不对。

论坛徽章:
0
4 [报告]
发表于 2003-07-01 16:28 |只看该作者

请教有关向表中插入记录的问题

nkliyong 说得对,sql 是不能直接使用declare,原来例子我是在
   存储过程中声明的,呵呵。
   
   仿照原来的例子,搞定了,谢nkliyong 提醒了!!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP