我有一个数据层类,我在其中创建方法中的所有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层。
有人可以帮忙吗?答案 0 :(得分:3)
你不应该这样做,因为这样的设计会导致很多问题:笨拙的测试,难以重构,依赖特定的数据库和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
// ...
}