2011-08-17 3 views
0

Ниже приведен пример использования списка ассоциаций взяты из BLToolkit http://bltoolkit.net/(S(ibvuiu3itvirtq550l4r0n55))/Doc.LinqAssociations.ashxBLToolkit Ассоциация Linq

[TableName("Categories")] 

public class Category 
    { 
     [PrimaryKey, Identity] public int CategoryID; 
     [NotNull]    public string CategoryName; 
           public string Description; 
           public Binary Picture; 

     [Association(ThisKey="CategoryID", OtherKey="CategoryID")] 
     public List<Product> Products; 
    } 

И

[TableName("Products")] 

public abstract class Product 
     { 
      [PrimaryKey, Identity]      public int  ProductID; 
      [NotNull]         public string ProductName; 
                 public int?  SupplierID; 
                 public int?  CategoryID; 
                 public string QuantityPerUnit; 
                 public decimal? UnitPrice; 
                 public short? UnitsInStock; 
                 public short? UnitsOnOrder; 
                 public short? ReorderLevel; 
      [MapField(IsInheritanceDiscriminator=true)] public bool  Discontinued; 

      [Association(ThisKey="ProductID", OtherKey="ProductID")] 
      public List<OrderDetail> OrderDetails; 

      [Association(ThisKey="CategoryID", OtherKey="CategoryID", CanBeNull=false)] 
      public Category Category; 

      [Association(ThisKey="SupplierID", OtherKey="SupplierID", CanBeNull=false)] 
      public Supplier Supplier; 
     } 

Когда я пытаюсь

using (var db = new NorthwindDB()) 
     { 
      var query = 
       from p in db.Product 
       select new 
       { 
        p.Category.CategoryName, 
        p.ProductName 
       }; 

      foreach (var item in query) 
      { 
       Console.WriteLine(item); 
      } 
     } 

возвращается с CategoryName продукта

Но когда я пытаюсь таким образом (как Linq2SQL)

var db1 = new NorthwindDB(); 
    db1.Product.First().Category.CategoryName; 

Категория возвращает нуль ????

ответ

0

Попробуйте

var db1 = new NorthwindDB(); 
db1.Product.Select(prod => prod.Category.CategoryName).First(); 

Я Думаю, что это делает то же самое. В любом случае о «как linq2Sql», L2S имеет ленивую загрузку, Blt не