Delphi ADO连接Oracel之怪情况(四)

Oracle数据库有一个伪列ROWID,使用指令SELECT ROWID,A.* FROM TableA A可以看到此列的值。不同的Oracle版本,此列的类型不同,此列在使用DESC指令查看表结构的时候看不到,是系统自动建立的,可以将其作为一个索引值。在数据库修改、删除的时候使用此列速度很快。

在Delphi中使用ADOQuery打开如下的SQL语句:SELECT ROWID,A.F1 FROM TableA A。Open之后,发现此ADOQuery的FieldCount =1,也就是说仅有F1这个列,看不到ROWID这一列,给ROWID列增加别名也不行。于是改为如下写法:SELECT ROWID||‘’ AS ID,A.F1 FROM TableA A。此时,FieldCount=2,可以投过FieldByName('ID')或者Fields[0]来取得这个值了。

好奇怪的一个问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值