通过数据提供者使用 ROWID 进行查询
我希望查询类似以下 sql 的表:
select * from itd093 where rowid='Cumn99AAAAMzAAAAAAJ'
它可以在 ADS 架构师客户端中找到唯一的记录。但是,当通过 .NET 数据提供程序从代码级别发送此查询时,它不会从数据库服务器返回任何结果。
有谁知道如何使上面的 sql 通过 .NET 数据提供程序返回结果?
这里有一些示例代码:
public void DataProviderTest()
{
using (AdsConnection conn = new AdsConnection(@"Data Source=D:\Development\FDDB;ServerType=ADS_LOCAL_SERVER;TableType=ADS_CDX;TrimTrailingSpaces=TRUE;"))
{
conn.Open();
AdsCommand cmd = new AdsCommand("select * from itd093 where rowid='Cumn99AAAAMzAAAAAJ'", conn);
AdsDataReader reader = cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
if (!reader.Read())
throw new Exception("no records");
}
}
I am looking to query a table like the following sql:
select * from itd093 where rowid='Cumn99AAAAMzAAAAAJ'
It could find a unique record in the ADS architect client. However, when this query was sent from the code level through the .NET data provider, it return none result from the database server.
Does anyone have ideas on how I can make the sql above return the result through the .NET data provider?
Some sample code here:
public void DataProviderTest()
{
using (AdsConnection conn = new AdsConnection(@"Data Source=D:\Development\FDDB;ServerType=ADS_LOCAL_SERVER;TableType=ADS_CDX;TrimTrailingSpaces=TRUE;"))
{
conn.Open();
AdsCommand cmd = new AdsCommand("select * from itd093 where rowid='Cumn99AAAAMzAAAAAJ'", conn);
AdsDataReader reader = cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
if (!reader.Read())
throw new Exception("no records");
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
感谢 Mark 指出 .NET 数据提供程序和 Advantage Data Architect 应返回相同的结果。
问题在于不同的连接字符串。从帮助文档来看,ROWID的前六个字符代表数据库ID。它基于连接路径。
我错误地从数据架构师那里复制了 rowid 来使用数据提供程序进行测试,并且连接字符串不同。这就是为什么我无法像从数据架构师那里那样从数据提供者那里获得返回的结果。
Thanks Mark for pointing out that the .NET data provider and the Advantage Data Architect should return the same result.
The problem to be the different connection strings. From the help documentation, it says,the first six characters of the ROWID represent the database ID. It is based on the connection path.
I was mistakenly copy a rowid from the data architect to test with data provider, and the connection strings are different. That's why I couldn't get a result returned from the data provider as it does from the data architect.