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]来取得这个值了。
好奇怪的一个问题。