Mercurial > pub > bltoolkit
view UnitTests/Linq/UserTests/SelectManyUpdateTest.cs @ 1:8f65451dc28f
Исправлена проблема с фабрикой и выборкой нескольких объектов в linq выражении
author | cin |
---|---|
date | Fri, 28 Mar 2014 01:04:56 +0400 |
parents | f990fcb411a9 |
children |
line wrap: on
line source
using System; using System.Collections.Generic; using System.Linq; using BLToolkit.Data.DataProvider; using BLToolkit.Data.Linq; using BLToolkit.DataAccess; using BLToolkit.Mapping; using NUnit.Framework; namespace Data.Linq.UserTests { [TestFixture] public class SelectManyUpdateTest : TestBase { public new class Child { [Identity, PrimaryKey(1)] public int ParentID { get; set; } [Nullable] public int? ChildID { get; set; } [AssociationAttribute(ThisKey = "ParentID", OtherKey = "ChildID", CanBeNull = true)] public List<Child> Children { get; set; } } public new class Parent { [Identity, PrimaryKey(1)] public int ParentID { get; set; } [Nullable] public int? Value1 { get; set; } [AssociationAttribute(ThisKey = "ParentID", OtherKey = "Value1", CanBeNull = true)] public List<Parent> Values { get; set; } [AssociationAttribute(ThisKey = "ParentID", OtherKey = "ParentID", CanBeNull = true)] public List<Child> Children { get; set; } } [Test] public void Test1([DataContexts(ProviderName.Access, ProviderName.Informix, ProviderName.MySql)] string context) { var harnessIds = new int[2]; using (var db = GetDataContext(context)) db.GetTable<Parent>() .Where (x => harnessIds.Contains(x.ParentID)) .SelectMany(x => x.Values) .Set (x => x.Value1, (long?)null) .Update(); } [Test] public void Test2([DataContexts(ProviderName.Access, ProviderName.Informix, ProviderName.MySql)] string context) { var harnessIds = new int[2]; using (var db = GetDataContext(context)) db.GetTable<Parent>() .Where (x => harnessIds.Contains(x.ParentID)) .SelectMany(x => x.Children) .SelectMany(x => x.Children) .Set (x => x.ChildID, 10) .Update(); } } }