![](/img/trans.png)
[英]SQL Server (ORM) select data from database - System.InvalidCastException
[英]“System.InvalidCastException” error when retrieving data from SQL Server 2012 Express
我正在嘗試測試一種從SQL Server 2012 Express實例檢索一些信息並將其“添加”到列表中的方法。 問題是當我嘗試運行測試時出現錯誤:
“ System.InvalidCastException”
這是代碼:
List<Reference> lst = new List<Reference>();
//DB Connections is a class instance that takes care of the
//connection with the db.
DBConnections db = new DBConnections(DbConfig.conStr);
db.UpdateCmd("SELECT * FROM freelancers_references");
SqlDataReader dr = db.ExecuteReader();
if (dr.HasRows) {
lst = dr.Cast<IDataRecord>().Select(r =>
new Reference {
Id = (int)dr["id"],
OwnerId = (int)dr["owner_id"],
Name = (string)dr["name"],
Active = (bool)dr["active"]
}).ToList<Reference>();
}
dr.Close();
return lst;
編輯:@丹提供了一個有效的答案。 盡管使用Convert.ToInt / ToString()等方法也能達到目的。
檢查列是否允許為空。 如果是這樣,則將類型設置為可為空
OwnerId = (int?)dr["owner_id"],
DBConnections db = new DBConnections(DbConfig.conStr);
db.UpdateCmd("SELECT * FROM freelancers_references");
SqlDataReader dr = db.ExecuteReader();
if (dr.HasRows) {
lst = dr.OfType<IDataRecord>().Select(r =>
new Reference {
Id = (int)dr["id"],
OwnerId = (int)dr["owner_id"],
Name = (string)dr["name"],
Active = (bool)dr["active"]
}).ToList();
}
dr.Close();
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.