繁体   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