簡體   English   中英

從數據層c#添加組合框項

[英]Add combo box items from data layer c#

我有一個數據層類,我在其中創建方法內的所有SQL語句。 在我的UI圖層中,我有一個組合框。 我想要做的是,我想從數據層填充組合框,而不是從UI層填充 到目前為止,我已在數據層中鍵入此代碼....

public void ComboImageList()
{
    try
    {
        SqlCommand command = new SqlCommand("SELECT ImageName FROM [ImageWithTags]", con);
        con.Open();
        SqlDataReader reader = command.ExecuteReader();

        while(reader.Read())
        {
          string name = reader.GetString(reader.GetOrdinal("ImageName"));
        }
        con.Close();
    }
    catch(Exception ex)
    {
        MessageBox.Show(ex.Message);
    } 
}

由於我無法直接從數據層訪問UI層,我不知道如何傳遞值。 我不知道我是否可以將組合框傳遞給數據層,或者我必須將字符串傳遞給UI層。

有人可以幫忙嗎?

你不應該這樣做,因為這樣的設計會導致很多問題:難以測試,難以重構,依賴於你不應該使用的特定數據庫和UI控件,很難從其他地方重用DAL。

User -> UI -> DAL -> Database
                         |
User <- UI <-  DAL <------

這樣做的正確方法是在DAL中使用方法

IEnumerable<string> GetNames()
{
    // execute your SQL and return result as some abstract collection
    using( /* connection setup */
    {
        using(var command = new SqlCommand("SELECT ImageName FROM [ImageWithTags]", con))
        {
            con.Open();  // check this, maybe it could be opened in first using
            SqlDataReader reader = command.ExecuteReader();
            while(reader.Read())
            {
                yield return  reader.GetString(reader.GetOrdinal("ImageName"));
            }
        }
    }
}

在UI層中,您可以這樣稱呼它

public void FillCombos()
{
    var repo = new DALRepo();
    var names = repo.GetNames();

    // now you can assign names to your combobox
    // ...
}

暫無
暫無

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

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