DB2 SQLCODE=-206, SQLSTATE=42703 定义表字段问题

本文转载自: https://www.cnblogs.com/hehongtao/p/5230269.html 作者:hehongtao 转载请注明该声明。

>[错误] 脚本行:1-1 ---------------------------------------

 "STATUS" is not valid in the context where it is used.. SQLCODE=-206, SQLSTATE=42703, DRIVER=3.53.71

 更多例外 ... An error occurred during implicit system action type "2". Information returned for the error includes SQLCODE "-206", SQLSTATE "42703" and message tokens "STATUS".. SQLCODE=-727, SQLSTATE=56098, DRIVER=3.53.71

 

执行SQL文时总是报这个错误,原因是:

在DB2中,默认情况下所有的名称都可包含一下字符:A-Z(大写) 0到9  @、#、$和_(下划线) 名称不能以数字和下划线开头。

数据库对象的表,其命名遵循以上规则,所以即使利用命令创建表时,使用的是小写,DB2仍会将其转换为大写。

但需要注意的是,并非db client软件也会自动转换,我在使用ibm data studio4或Aqua data studio等客户端时,发现统计studio 提供的图形界面创建,并不能自动转换为大写,

比如使用studio创建表时将字段定义为小写的status,这样再使用普通的SQL语句操作,例如:

select * from LARGE_RECEIPT where status='E' 就会报错

解决方法:定义时用大写字母

 

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值