sybase 的 SQL 语法问题-----exist的困惑
时间:2010-12-09
来源:互联网
本希望在SHELL中实现如果库mydb中有表table1时就作update 操作,
isql -Uuser -P123 <<!!
use mydb
go
if ( exists ( select 1 from sysobjects where type='U' and name='table1' ) )
begin
print "开始测试"
update table1 set seg1="123"
end
go
!!
测试结果遇到如下情况,不甚了解:
1: 如果 table1 确实存在,执行正常
2: 如果 table1 不存在,该语句根本无法执行(直接报 table1 不存在)
初步分析,是 SYBASE 先作了解析因此,无法执行
但是如果把 update 换成 drop 语句,不管table1是否存在,语句均执行正常,也就推翻了自己的分析
if ( exists ( select 1 from sysobjects where type='U' and name='table1' ) )
begin
print "开始测试"
drop table table1
end
go
求解?
isql -Uuser -P123 <<!!
use mydb
go
if ( exists ( select 1 from sysobjects where type='U' and name='table1' ) )
begin
print "开始测试"
update table1 set seg1="123"
end
go
!!
测试结果遇到如下情况,不甚了解:
1: 如果 table1 确实存在,执行正常
2: 如果 table1 不存在,该语句根本无法执行(直接报 table1 不存在)
初步分析,是 SYBASE 先作了解析因此,无法执行
但是如果把 update 换成 drop 语句,不管table1是否存在,语句均执行正常,也就推翻了自己的分析
if ( exists ( select 1 from sysobjects where type='U' and name='table1' ) )
begin
print "开始测试"
drop table table1
end
go
求解?
作者: luopc 发布时间: 2010-12-09
if ( exists ( select 1 from sysobjects where type='U' and name='table1' ) )
begin
print "开始测试"
declare @cmdstr varchar(100)
select @cmdstr='update table1 set seg1="123"'
execute(@cmdstr)
end
go
begin
print "开始测试"
declare @cmdstr varchar(100)
select @cmdstr='update table1 set seg1="123"'
execute(@cmdstr)
end
go
作者: Eisen 发布时间: 2010-12-10
asa15.5中有个选项:Deferred Name Resolution
对这个情况比较实用~
对这个情况比较实用~
作者: andkylee 发布时间: 2010-12-10
QUOTE:
asa15.5中有个选项:Deferred Name Resolution
对这个情况比较实用~
andkylee 发表于 2010-12-10 09:39
对这个情况比较实用~
andkylee 发表于 2010-12-10 09:39
哈,这个feature是个西班牙人写的
作者: shakeone 发布时间: 2010-12-10
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28