2

私はNHibernateプロジェクションに慣れていません。IList<>ではなくList<>を返すことができるように使用しようとしています。私はまだDTOに投影することにあまり運がありません。次のクエリオブジェクトとドメインオブジェクトがあります。まず、EmployeeIDを指定して注文のリストを取得しようとしています。このリストをシリアル化できるようにしたいので、結果のリストをループしてリストに追加しています。誰かが私がプロジェクションからどれだけ離れているか教えてもらえますか?私は自分のものと似ていないいくつかの例を検索して見つけました。基本的に..DTOのリストを作成したいだけです。

ありがとう!

public List<EmployeeOrder> GetEmployessOrdersDTO(int empid)
        {
        var emporders = new List<EmployeeOrder>();

        ICriteria criteriaSelect = NHibernateSessionManager.Instance.GetSession().CreateCriteria(typeof (Orders))
            .CreateCriteria("Employees")
            .Add(Expression.Eq("EmployeeID", empid));

        criteriaSelect.SetProjection(
            Projections.ProjectionList()
            .Add(Projections.Property("Products"), "OrderedProducts"));


        criteriaSelect.SetResultTransformer(NHibernate.Transform.Transformers.AliasToBean(typeof(EmployeeOrder)));
        criteriaSelect.List<EmployeeOrder>();

        foreach (var order in emporders)
        {
            emporders.Add(order);
        }
        return emporders;
    }

注文:

 public class Orders
{
    public virtual int OrderID { get; private set;}
    public virtual string CustomerID { get; set; }
    public virtual DateTime OrderDate { get; set; }
    public virtual DateTime RequiredDate { get; set; }
    public virtual DateTime ShippedDate { get; set; }
    public virtual Employees Employee { get; set; }
    public virtual IList<Products> Products { get; private set; }

}

従業員:

public class Employees
{

    public virtual int EmployeeID { get; private set;}
    public virtual string LastName { get; set;}
    public virtual string FirstName { get; set;}
    public virtual string City { get; set; }
    public virtual DateTime HireDate { get; set; }
    public virtual string Title { get; set; }
    public virtual IList<Orders> Orders { get; private set; }

}

EmployeeOrderDTO:

public class EmployeeOrder
{
    public virtual string EmployeeName { get; set; }
    public virtual string EmployeeTitle { get; set; }
    public virtual DateTime RequiredDate { get; set; }
    public virtual List<Products> OrderedProducts { get; set; }
}
4

2 に答える 2

4

nHibernate 2.1では、.List()メソッドは実際にはすでにListタイプを返すため、次のようにキャストできます。

var list = (List<EmployeeOrder>)criteriaSelect.List<EmployeeOrder>();

ただし、将来的に安全であり、現在のnHibernateの実装に基づく仮定に依存しないようにしたい場合は、ICriteriaを受け入れる拡張メソッドを作成します。

  public static List<T> ToList<T>(this ICriteria criteria)
  {
    return criteria.List<T>().ToList();
  }
于 2009-09-28T11:25:45.417 に答える
2

変化する

criteriaSelect.List<EmployeeOrder>();

List<EmployeeOrder> employeeOrders = criteriaSelect.List<EmployeeOrder>() as List<EmployeeOrder>;
于 2009-04-28T05:00:09.200 に答える