簡體   English   中英

從Web服務獲取返回列表

[英]Getting returned list from web service

我編寫了一個相當簡單的Web服務,將SQL查詢的結果集放入列表中。 我在使用Web服務的項目中調用帶有結果集的列表時遇到麻煩。 我將代碼放在下面:

網絡服務

[OperationContract]
List<ViewDetails> ViewDetails();

[DataContract]
public class ViewDetails
{
    public string TitleView { get; set; }
    public string BodyView { get; set; }
    public string AuthorView { get; set; }

    public ViewDetails() { }
    public ViewDetails(string myTitleView, string myBodyView, string myAuthorView)
    {
        this.TitleView = myTitleView;
        this.BodyView = myBodyView;
        this.AuthorView = myAuthorView;
    }
}

 public List<ViewDetails> ViewDetails()
    {
        List<ViewDetails> details = new List<ViewDetails>();

        SqlConnection conn = new SqlConnection(strConnString);
        conn.Open();
        SqlCommand cmd = new SqlCommand("SELECT TOP 2 [My_Title] AS 'Title', [My_Body] AS 'Body', [My_Author] AS 'Author' FROM [My_table] ORDER BY [Date] DESC", conn);
        SqlDataReader rdrDetails = cmd.ExecuteReader();

        try
        {
            while (rdrDetails.Read())
            {
                details.Add(new ViewDetails(rdrDetails.GetSqlString(rdrDetails.GetOrdinal("Title")).ToString(), rdrDetails.GetSqlString(rdrDetails.GetOrdinal("Body")).ToString(), rdrDetails.GetSqlString(rdrDetails.GetOrdinal("Author")).ToString()));
            }
        }
        catch (Exception e)
        {
            //exception
        }
        finally
        {
            conn.Close();
        }

        return details;
    }

我正在使用Web服務的項目

 public async void ViewData()
 {
        ServiceReference1.Service1Client client = new ServiceReference1.Service1Client();
        string title = string.Empty;
        string body = string.Empty;
        string author = string.Empty;

        var res = await client.ViewDetailsAsync();
  }

我希望能夠在ViewData類中執行類似的操作,以便將結果存儲在變量中並將其分配給textblocks等。

title = res.TitleView;

但這不允許我...。有人看到我想念的東西嗎?

注意 :這是一個通用Windows應用程序

您缺少resList<ViewDetails> res不是ViewDetails的實例。 因此,您應該輸入title = res[0].TitleView;

您在ViewDetails數據合同屬性中缺少DataMember屬性。

[DataContract]
public class ViewDetails
{
   [DataMember]  
   public string TitleView { get; set; }
   [DataMember]
   public string BodyView { get; set; }
   [DataMember]
   public string AuthorView { get; set; }

    public ViewDetails() { }
    public ViewDetails(string myTitleView, string myBodyView, string myAuthorView)
    {
     this.TitleView = myTitleView;
     this.BodyView = myBodyView;
     this.AuthorView = myAuthorView;
    }
}

暫無
暫無

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

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