簡體   English   中英

C#-使用DataRow從一行獲取記錄

[英]C# - Getting record from a row using DataRow

我正在嘗試使用DataRow獲取行的記錄。 到目前為止,這是我所做的:

 uID = int.Parse(Request.QueryString["id"]);
 PhotoDataSetTableAdapters.MembersTableAdapter mem = new PhotoDataSetTableAdapters.MembersTableAdapter();
 PhotoDataSet.MembersDataTable memTable = mem.GetMemberByID(uID);
 DataRow[] dr = memTable.Select("userID = uID");
 string uName = dr["username"].ToString();

然后我得到了錯誤:

無法將類型'string'隱式轉換為'int'

錯誤指向"username" 我不知道這是怎么回事,因為我只是想將一個字符串變量分配給一個字符串值。 有人找出錯誤的原因嗎? 請幫忙,謝謝。

更改以下語句

DataRow[] dr = memTable.Select("userID = uID");

DataRow[] dr = memTable.Select("userID = "+ uID);

dr是一個DataRow[]而不是DataRow ,因此編譯器抱怨說,當他需要一個int作為索引時,您傳遞了一個String。

您實際上想要的是DataTable單個DataRow的用戶名,對嗎?

String uName = memTable.AsEnumerable().Single().Field<String>("username");

請注意,如果DataTable有多行,則會引發異常。 但是,由於您將ID傳遞給DataAdapter ,因此我假設它應該僅返回一條記錄。

似乎有兩個問題。 正如Asif所建議的那樣,uID應該為“ userId =” + uID(可能應將uID強制轉換為字符串),而正如Tim所指出的那樣,dr是一組數據行。 您也可以通過索引訪問它:dr [0] [“ userName”]。ToString()

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM