我正在尝试通过 Silverlight 应用程序的 WCF 服务访问 SQL 数据库,并且由于某种原因,我的SqlDataReader
对象不断给我错误。我只是试图从数据库中检索一个值。
这是我现在的代码:
using(SqlConnection oConnection = new SqlConnection(ConnectionString))
{
SqlCommand oCommand = new SqlCommand("SELECT SystemVersNo FROM dbo.CoPolicyPointer WHERE SystemAssignId = '58859700000000'");
CompositeType oCustomer = new CompositeType();
SqlDataReader oReader = null;
oConnection.Open();
oCommand.Connection = oConnection;
oReader = oCommand.ExecuteReader();
if (oReader.HasRows)
{
oCustomer.SRVNo = oReader.GetValue(0).ToString();
}
else
{
oCustomer.SRVNo = "No rows returned.";
}
oConnection.Close();
return oCustomer;
}
oReader.HasRows
返回 true,但oReader.GetValue(0)
(或 oReader.GetAnythingElse,就此而言)抛出错误:
System.InvalidOperationException:不存在数据时尝试读取无效。
不过,真正难倒我的是,如果我调用oReader.GetOrdinal("SystemVersNo")
, or oReader.GetName(0)
,它们都会返回正确的值。序数位置如何返回零,但在该位置找不到要读取的值?如果我在 SQL Server Management Studio 中运行相同的查询,值就不会出现问题,所以我知道它就在那里。
我对这一切都是全新的,我错过了一些基本的东西吗?或者有什么时髦的事情发生。
谢谢!