如何使用myGeneration从BusinessEntity获取对象列表?

时间:2010-02-27 22:35:18

标签: c# code-generation mygeneration

我在某些项目中使用了myGeneration;我注意到BusinessEntity将查询结果保存在DataTable中, 但是如果开发人员希望将结果作为对象列表呢? 为了解决这个问题,我做了以下修改供我自己使用。

public  class BusinessEntity

{
    //....
    public DataTable TheDataTable
    {
        get
        {
            return _dataTable;
        }
        set
        {
            _dataTable = value;
        }
    }

    public void PutTheRow(DataRow pRow)
    {

        DataRow newRow = _dataTable.NewRow();
        newRow.ItemArray = pRow.ItemArray;
        _dataTable.Rows.Add(newRow);
        _dataRow = newRow;
        //Rewind();
        _dataTable.AcceptChanges();

    }

    .......


}

现在假设我们有一个表“Employee”,我们为他生成一个类,我也进行了以下修改:

public abstract class Employee : _Employee
{
    public Employee()
    {

    }
    public List<Employee> AsList()
    {

        List<Employee> list = new List<Employee>();
        Employee businessEntity = null;
        foreach (System.Data.DataRow row in TheDataTable.Rows)
        {
            businessEntity = new Employee();
            businessEntity.TheDataTable = TheDataTable.Clone();
            businessEntity.PutTheRow(row);
            list.Add(businessEntity);


        }
        return list;
    }
}

现在我可以从查询结果中获取一个对象列表,而不是一个对象和数据表中的结果:

Employee employee = new Employee();
    employee.Where.ID.Operator = WhereParameter.Operand.NotIn;
    employee.Where.ID.Value = "1,2,3";
    employee.Query.Load();
    foreach (Employee employeeLoop in employee.AsList())
    {
        TreeNode node = new TreeNode(employeeLoop.s_ID);
        node.Tag = employeeLoop;
        mMainTree.Nodes.Add(node);
}

然后我可以按以下方式访问所选的员工:

Employee emp = (Employee) mMainTree.SelectedNode.Tag;
emp.Name = "WWWWW";
emp.Save();

感谢。 你有更好的提示,想法吗? 有关更多讨论,请访问MyGeneration论坛。

1 个答案:

答案 0 :(得分:0)

为什么要创建一个只返回一个Item的AsList()方法?你可以像这样创建一个通用的扩展方法(从头顶创建......):

public static List<T> AsList(this T item)
{
   return new List<T>() { item };
}

没有必要遍历一个Employee List来将它添加到TreeNode。