You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
EntityFrameworkCore.Jet/test/EFCore.Jet.FunctionalTests/InheritanceRelationshipsQue...

789 lines
40 KiB
C#

using Microsoft.EntityFrameworkCore.Query;
using Xunit.Abstractions;
namespace EntityFramework.Jet.FunctionalTests
{
public class InheritanceRelationshipsQueryJetTest
: InheritanceRelationshipsQueryTestBase<InheritanceRelationshipsQueryJetFixture>
{
public InheritanceRelationshipsQueryJetTest(
InheritanceRelationshipsQueryJetFixture fixture, ITestOutputHelper testOutputHelper)
: base(fixture)
{
fixture.TestSqlLoggerFactory.Clear();
}
public override void Include_reference_with_inheritance1()
{
base.Include_reference_with_inheritance1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase].*
FROM [BaseReferenceOnBase] AS [e.BaseReferenceOnBase]
WHERE [e.BaseReferenceOnBase].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t] ON [e].[Id] = [t].[BaseParentId]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')");
}
public override void Include_reference_with_inheritance_reverse()
{
base.Include_reference_with_inheritance_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[BaseParentId], [e].[Discriminator], [e].[Name], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [BaseReferenceOnBase] AS [e]
LEFT JOIN (
SELECT [e.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.BaseParent]
WHERE [e.BaseParent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e].[BaseParentId] = [t].[Id]
WHERE [e].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')");
}
public override void Include_self_refence_with_inheritence()
{
base.Include_self_refence_with_inheritence();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.DerivedSefReferenceOnBase].*
FROM [BaseInheritanceRelationshipEntity] AS [e.DerivedSefReferenceOnBase]
WHERE [e.DerivedSefReferenceOnBase].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
) AS [t] ON [e].[Id] = [t].[BaseId]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')");
}
public override void Include_self_refence_with_inheritence_reverse()
{
base.Include_self_refence_with_inheritence_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseSelfRerefenceOnDerived].*
FROM [BaseInheritanceRelationshipEntity] AS [e.BaseSelfRerefenceOnDerived]
WHERE [e.BaseSelfRerefenceOnDerived].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e].[BaseId] = [t].[Id]
WHERE [e].[Discriminator] = 'DerivedInheritanceRelationshipEntity'");
}
public override void Include_reference_with_inheritance_with_filter1()
{
base.Include_reference_with_inheritance_with_filter1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase].*
FROM [BaseReferenceOnBase] AS [e.BaseReferenceOnBase]
WHERE [e.BaseReferenceOnBase].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t] ON [e].[Id] = [t].[BaseParentId]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity') AND (([e].[Name] <> 'Bar') OR [e].[Name] IS NULL)");
}
public override void Include_reference_with_inheritance_with_filter_reverse()
{
base.Include_reference_with_inheritance_with_filter_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[BaseParentId], [e].[Discriminator], [e].[Name], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [BaseReferenceOnBase] AS [e]
LEFT JOIN (
SELECT [e.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.BaseParent]
WHERE [e.BaseParent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e].[BaseParentId] = [t].[Id]
WHERE [e].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase') AND (([e].[Name] <> 'Bar') OR [e].[Name] IS NULL)");
}
public override void Include_reference_without_inheritance()
{
base.Include_reference_without_inheritance();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [e.ReferenceOnBase].[Id], [e.ReferenceOnBase].[Name], [e.ReferenceOnBase].[ParentId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN [ReferenceOnBase] AS [e.ReferenceOnBase] ON [e].[Id] = [e.ReferenceOnBase].[ParentId]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')");
}
public override void Include_reference_without_inheritance_reverse()
{
base.Include_reference_without_inheritance_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Name], [e].[ParentId], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [ReferenceOnBase] AS [e]
LEFT JOIN (
SELECT [e.Parent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.Parent]
WHERE [e.Parent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e].[ParentId] = [t].[Id]");
}
public override void Include_reference_without_inheritance_with_filter()
{
base.Include_reference_without_inheritance_with_filter();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [e.ReferenceOnBase].[Id], [e.ReferenceOnBase].[Name], [e.ReferenceOnBase].[ParentId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN [ReferenceOnBase] AS [e.ReferenceOnBase] ON [e].[Id] = [e.ReferenceOnBase].[ParentId]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity') AND (([e].[Name] <> 'Bar') OR [e].[Name] IS NULL)");
}
public override void Include_reference_without_inheritance_with_filter_reverse()
{
base.Include_reference_without_inheritance_with_filter_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Name], [e].[ParentId], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [ReferenceOnBase] AS [e]
LEFT JOIN (
SELECT [e.Parent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.Parent]
WHERE [e.Parent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e].[ParentId] = [t].[Id]
WHERE ([e].[Name] <> 'Bar') OR [e].[Name] IS NULL");
}
public override void Include_collection_with_inheritance1()
{
base.Include_collection_with_inheritance1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
ORDER BY [e].[Id]",
//
@"SELECT [e#BaseCollectionOnBase].[Id], [e#BaseCollectionOnBase].[BaseParentId], [e#BaseCollectionOnBase].[Discriminator], [e#BaseCollectionOnBase].[Name], [e#BaseCollectionOnBase].[DerivedProperty]
FROM [BaseCollectionOnBase] AS [e#BaseCollectionOnBase]
INNER JOIN (
SELECT [e0].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e0]
WHERE [e0].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e#BaseCollectionOnBase].[BaseParentId] = [t].[Id]
WHERE [e#BaseCollectionOnBase].[Discriminator] IN ('DerivedCollectionOnBase', 'BaseCollectionOnBase')
ORDER BY [t].[Id]");
}
public override void Include_collection_with_inheritance_reverse()
{
base.Include_collection_with_inheritance_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[BaseParentId], [e].[Discriminator], [e].[Name], [e].[DerivedProperty], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [BaseCollectionOnBase] AS [e]
LEFT JOIN (
SELECT [e.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.BaseParent]
WHERE [e.BaseParent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e].[BaseParentId] = [t].[Id]
WHERE [e].[Discriminator] IN ('DerivedCollectionOnBase', 'BaseCollectionOnBase')");
}
public override void Include_collection_with_inheritance_with_filter1()
{
base.Include_collection_with_inheritance_with_filter1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity') AND (([e].[Name] <> 'Bar') OR [e].[Name] IS NULL)
ORDER BY [e].[Id]",
//
@"SELECT [e#BaseCollectionOnBase].[Id], [e#BaseCollectionOnBase].[BaseParentId], [e#BaseCollectionOnBase].[Discriminator], [e#BaseCollectionOnBase].[Name], [e#BaseCollectionOnBase].[DerivedProperty]
FROM [BaseCollectionOnBase] AS [e#BaseCollectionOnBase]
INNER JOIN (
SELECT [e0].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e0]
WHERE [e0].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity') AND (([e0].[Name] <> 'Bar') OR [e0].[Name] IS NULL)
) AS [t] ON [e#BaseCollectionOnBase].[BaseParentId] = [t].[Id]
WHERE [e#BaseCollectionOnBase].[Discriminator] IN ('DerivedCollectionOnBase', 'BaseCollectionOnBase')
ORDER BY [t].[Id]");
}
public override void Include_collection_with_inheritance_with_filter_reverse()
{
base.Include_collection_with_inheritance_with_filter_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[BaseParentId], [e].[Discriminator], [e].[Name], [e].[DerivedProperty], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [BaseCollectionOnBase] AS [e]
LEFT JOIN (
SELECT [e.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.BaseParent]
WHERE [e.BaseParent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e].[BaseParentId] = [t].[Id]
WHERE [e].[Discriminator] IN ('DerivedCollectionOnBase', 'BaseCollectionOnBase') AND (([e].[Name] <> 'Bar') OR [e].[Name] IS NULL)");
}
public override void Include_collection_without_inheritance()
{
base.Include_collection_without_inheritance();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
ORDER BY [e].[Id]",
//
@"SELECT [e.CollectionOnBase].[Id], [e.CollectionOnBase].[Name], [e.CollectionOnBase].[ParentId]
FROM [CollectionOnBase] AS [e.CollectionOnBase]
INNER JOIN (
SELECT [e0].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e0]
WHERE [e0].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e.CollectionOnBase].[ParentId] = [t].[Id]
ORDER BY [t].[Id]");
}
public override void Include_collection_without_inheritance_reverse()
{
base.Include_collection_without_inheritance_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Name], [e].[ParentId], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [CollectionOnBase] AS [e]
LEFT JOIN (
SELECT [e.Parent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.Parent]
WHERE [e.Parent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e].[ParentId] = [t].[Id]");
}
public override void Include_collection_without_inheritance_with_filter()
{
base.Include_collection_without_inheritance_with_filter();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity') AND (([e].[Name] <> 'Bar') OR [e].[Name] IS NULL)
ORDER BY [e].[Id]",
//
@"SELECT [e.CollectionOnBase].[Id], [e.CollectionOnBase].[Name], [e.CollectionOnBase].[ParentId]
FROM [CollectionOnBase] AS [e.CollectionOnBase]
INNER JOIN (
SELECT [e0].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e0]
WHERE [e0].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity') AND (([e0].[Name] <> 'Bar') OR [e0].[Name] IS NULL)
) AS [t] ON [e.CollectionOnBase].[ParentId] = [t].[Id]
ORDER BY [t].[Id]");
}
public override void Include_collection_without_inheritance_with_filter_reverse()
{
base.Include_collection_without_inheritance_with_filter_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Name], [e].[ParentId], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [CollectionOnBase] AS [e]
LEFT JOIN (
SELECT [e.Parent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.Parent]
WHERE [e.Parent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e].[ParentId] = [t].[Id]
WHERE ([e].[Name] <> 'Bar') OR [e].[Name] IS NULL");
}
public override void Include_reference_with_inheritance_on_derived1()
{
base.Include_reference_with_inheritance_on_derived1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase].*
FROM [BaseReferenceOnBase] AS [e.BaseReferenceOnBase]
WHERE [e.BaseReferenceOnBase].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t] ON [e].[Id] = [t].[BaseParentId]
WHERE [e].[Discriminator] = 'DerivedInheritanceRelationshipEntity'");
}
public override void Include_reference_with_inheritance_on_derived2()
{
base.Include_reference_with_inheritance_on_derived2();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name], [t].[DerivedInheritanceRelationshipEntityId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseReferenceOnDerived].*
FROM [BaseReferenceOnDerived] AS [e.BaseReferenceOnDerived]
WHERE [e.BaseReferenceOnDerived].[Discriminator] IN ('DerivedReferenceOnDerived', 'BaseReferenceOnDerived')
) AS [t] ON [e].[Id] = [t].[BaseParentId]
WHERE [e].[Discriminator] = 'DerivedInheritanceRelationshipEntity'");
}
public override void Include_reference_with_inheritance_on_derived4()
{
base.Include_reference_with_inheritance_on_derived4();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name], [t].[DerivedInheritanceRelationshipEntityId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.DerivedReferenceOnDerived].*
FROM [BaseReferenceOnDerived] AS [e.DerivedReferenceOnDerived]
WHERE [e.DerivedReferenceOnDerived].[Discriminator] = 'DerivedReferenceOnDerived'
) AS [t] ON [e].[Id] = [t].[DerivedInheritanceRelationshipEntityId]
WHERE [e].[Discriminator] = 'DerivedInheritanceRelationshipEntity'");
}
public override void Include_reference_with_inheritance_on_derived_reverse()
{
base.Include_reference_with_inheritance_on_derived_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[BaseParentId], [e].[Discriminator], [e].[Name], [e].[DerivedInheritanceRelationshipEntityId], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [BaseReferenceOnDerived] AS [e]
LEFT JOIN (
SELECT [e.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.BaseParent]
WHERE [e.BaseParent].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
) AS [t] ON [e].[BaseParentId] = [t].[Id]
WHERE [e].[Discriminator] IN ('DerivedReferenceOnDerived', 'BaseReferenceOnDerived')");
}
public override void Include_reference_with_inheritance_on_derived_with_filter1()
{
base.Include_reference_with_inheritance_on_derived_with_filter1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase].*
FROM [BaseReferenceOnBase] AS [e.BaseReferenceOnBase]
WHERE [e.BaseReferenceOnBase].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t] ON [e].[Id] = [t].[BaseParentId]
WHERE ([e].[Discriminator] = 'DerivedInheritanceRelationshipEntity') AND (([e].[Name] <> 'Bar') OR [e].[Name] IS NULL)");
}
public override void Include_reference_with_inheritance_on_derived_with_filter2()
{
base.Include_reference_with_inheritance_on_derived_with_filter2();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name], [t].[DerivedInheritanceRelationshipEntityId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseReferenceOnDerived].*
FROM [BaseReferenceOnDerived] AS [e.BaseReferenceOnDerived]
WHERE [e.BaseReferenceOnDerived].[Discriminator] IN ('DerivedReferenceOnDerived', 'BaseReferenceOnDerived')
) AS [t] ON [e].[Id] = [t].[BaseParentId]
WHERE ([e].[Discriminator] = 'DerivedInheritanceRelationshipEntity') AND (([e].[Name] <> 'Bar') OR [e].[Name] IS NULL)");
}
public override void Include_reference_with_inheritance_on_derived_with_filter4()
{
base.Include_reference_with_inheritance_on_derived_with_filter4();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name], [t].[DerivedInheritanceRelationshipEntityId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.DerivedReferenceOnDerived].*
FROM [BaseReferenceOnDerived] AS [e.DerivedReferenceOnDerived]
WHERE [e.DerivedReferenceOnDerived].[Discriminator] = 'DerivedReferenceOnDerived'
) AS [t] ON [e].[Id] = [t].[DerivedInheritanceRelationshipEntityId]
WHERE ([e].[Discriminator] = 'DerivedInheritanceRelationshipEntity') AND (([e].[Name] <> 'Bar') OR [e].[Name] IS NULL)");
}
public override void Include_reference_with_inheritance_on_derived_with_filter_reverse()
{
base.Include_reference_with_inheritance_on_derived_with_filter_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[BaseParentId], [e].[Discriminator], [e].[Name], [e].[DerivedInheritanceRelationshipEntityId], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [BaseReferenceOnDerived] AS [e]
LEFT JOIN (
SELECT [e.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.BaseParent]
WHERE [e.BaseParent].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
) AS [t] ON [e].[BaseParentId] = [t].[Id]
WHERE [e].[Discriminator] IN ('DerivedReferenceOnDerived', 'BaseReferenceOnDerived') AND (([e].[Name] <> 'Bar') OR [e].[Name] IS NULL)");
}
public override void Include_reference_without_inheritance_on_derived1()
{
base.Include_reference_without_inheritance_on_derived1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [e.ReferenceOnBase].[Id], [e.ReferenceOnBase].[Name], [e.ReferenceOnBase].[ParentId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN [ReferenceOnBase] AS [e.ReferenceOnBase] ON [e].[Id] = [e.ReferenceOnBase].[ParentId]
WHERE [e].[Discriminator] = 'DerivedInheritanceRelationshipEntity'");
}
public override void Include_reference_without_inheritance_on_derived2()
{
base.Include_reference_without_inheritance_on_derived2();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [e.ReferenceOnDerived].[Id], [e.ReferenceOnDerived].[Name], [e.ReferenceOnDerived].[ParentId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN [ReferenceOnDerived] AS [e.ReferenceOnDerived] ON [e].[Id] = [e.ReferenceOnDerived].[ParentId]
WHERE [e].[Discriminator] = 'DerivedInheritanceRelationshipEntity'");
}
public override void Include_reference_without_inheritance_on_derived_reverse()
{
base.Include_reference_without_inheritance_on_derived_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Name], [e].[ParentId], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [ReferenceOnDerived] AS [e]
LEFT JOIN (
SELECT [e.Parent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.Parent]
WHERE [e.Parent].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
) AS [t] ON [e].[ParentId] = [t].[Id]");
}
public override void Include_collection_with_inheritance_on_derived1()
{
base.Include_collection_with_inheritance_on_derived1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
WHERE [e].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
ORDER BY [e].[Id]",
//
@"SELECT [e#BaseCollectionOnBase].[Id], [e#BaseCollectionOnBase].[BaseParentId], [e#BaseCollectionOnBase].[Discriminator], [e#BaseCollectionOnBase].[Name], [e#BaseCollectionOnBase].[DerivedProperty]
FROM [BaseCollectionOnBase] AS [e#BaseCollectionOnBase]
INNER JOIN (
SELECT [e0].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e0]
WHERE [e0].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
) AS [t] ON [e#BaseCollectionOnBase].[BaseParentId] = [t].[Id]
WHERE [e#BaseCollectionOnBase].[Discriminator] IN ('DerivedCollectionOnBase', 'BaseCollectionOnBase')
ORDER BY [t].[Id]");
}
public override void Include_collection_with_inheritance_on_derived2()
{
base.Include_collection_with_inheritance_on_derived2();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
WHERE [e].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
ORDER BY [e].[Id]",
//
@"SELECT [e.BaseCollectionOnDerived].[Id], [e.BaseCollectionOnDerived].[Discriminator], [e.BaseCollectionOnDerived].[Name], [e.BaseCollectionOnDerived].[ParentId], [e.BaseCollectionOnDerived].[DerivedInheritanceRelationshipEntityId]
FROM [BaseCollectionOnDerived] AS [e.BaseCollectionOnDerived]
INNER JOIN (
SELECT [e0].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e0]
WHERE [e0].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
) AS [t] ON [e.BaseCollectionOnDerived].[ParentId] = [t].[Id]
WHERE [e.BaseCollectionOnDerived].[Discriminator] IN ('DerivedCollectionOnDerived', 'BaseCollectionOnDerived')
ORDER BY [t].[Id]");
}
public override void Include_collection_with_inheritance_on_derived3()
{
base.Include_collection_with_inheritance_on_derived3();
AssertSql(
@"");
}
public override void Include_collection_with_inheritance_on_derived_reverse()
{
base.Include_collection_with_inheritance_on_derived_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[ParentId], [e].[DerivedInheritanceRelationshipEntityId], [t].[Id], [t].[Discriminator], [t].[Name], [t].[BaseId]
FROM [BaseCollectionOnDerived] AS [e]
LEFT JOIN (
SELECT [e.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.BaseParent]
WHERE [e.BaseParent].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
) AS [t] ON [e].[ParentId] = [t].[Id]
WHERE [e].[Discriminator] IN ('DerivedCollectionOnDerived', 'BaseCollectionOnDerived')");
}
public override void Nested_include_with_inheritance_reference_reference1()
{
base.Nested_include_with_inheritance_reference_reference1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name], [t0].[Id], [t0].[Discriminator], [t0].[Name], [t0].[ParentCollectionId], [t0].[ParentReferenceId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase].*
FROM [BaseReferenceOnBase] AS [e.BaseReferenceOnBase]
WHERE [e.BaseReferenceOnBase].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t] ON [e].[Id] = [t].[BaseParentId]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase.NestedReference].*
FROM [NestedReferenceBase] AS [e.BaseReferenceOnBase.NestedReference]
WHERE [e.BaseReferenceOnBase.NestedReference].[Discriminator] IN ('NestedReferenceDerived', 'NestedReferenceBase')
) AS [t0] ON [t].[Id] = [t0].[ParentReferenceId]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')");
}
public override void Nested_include_with_inheritance_reference_reference3()
{
base.Nested_include_with_inheritance_reference_reference3();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name], [t0].[Id], [t0].[Discriminator], [t0].[Name], [t0].[ParentCollectionId], [t0].[ParentReferenceId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase].*
FROM [BaseReferenceOnBase] AS [e.BaseReferenceOnBase]
WHERE [e.BaseReferenceOnBase].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t] ON [e].[Id] = [t].[BaseParentId]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase.NestedReference].*
FROM [NestedReferenceBase] AS [e.BaseReferenceOnBase.NestedReference]
WHERE [e.BaseReferenceOnBase.NestedReference].[Discriminator] IN ('NestedReferenceDerived', 'NestedReferenceBase')
) AS [t0] ON [t].[Id] = [t0].[ParentReferenceId]
WHERE [e].[Discriminator] = 'DerivedInheritanceRelationshipEntity'");
}
public override void Nested_include_with_inheritance_reference_reference_reverse()
{
base.Nested_include_with_inheritance_reference_reference_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[ParentCollectionId], [e].[ParentReferenceId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name], [t0].[Id], [t0].[Discriminator], [t0].[Name], [t0].[BaseId]
FROM [NestedReferenceBase] AS [e]
LEFT JOIN (
SELECT [e.ParentReference].*
FROM [BaseReferenceOnBase] AS [e.ParentReference]
WHERE [e.ParentReference].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t] ON [e].[ParentReferenceId] = [t].[Id]
LEFT JOIN (
SELECT [e.ParentReference.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.ParentReference.BaseParent]
WHERE [e.ParentReference.BaseParent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t0] ON [t].[BaseParentId] = [t0].[Id]
WHERE [e].[Discriminator] IN ('NestedReferenceDerived', 'NestedReferenceBase')");
}
public override void Nested_include_with_inheritance_reference_collection1()
{
base.Nested_include_with_inheritance_reference_collection1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase].*
FROM [BaseReferenceOnBase] AS [e.BaseReferenceOnBase]
WHERE [e.BaseReferenceOnBase].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t] ON [e].[Id] = [t].[BaseParentId]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
ORDER BY [t].[Id]",
//
@"SELECT [e.BaseReferenceOnBase.NestedCollection].[Id], [e.BaseReferenceOnBase.NestedCollection].[Discriminator], [e.BaseReferenceOnBase.NestedCollection].[Name], [e.BaseReferenceOnBase.NestedCollection].[ParentCollectionId], [e.BaseReferenceOnBase.NestedCollection].[ParentReferenceId]
FROM [NestedCollectionBase] AS [e.BaseReferenceOnBase.NestedCollection]
INNER JOIN (
SELECT DISTINCT [t0].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e0]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase0].*
FROM [BaseReferenceOnBase] AS [e.BaseReferenceOnBase0]
WHERE [e.BaseReferenceOnBase0].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t0] ON [e0].[Id] = [t0].[BaseParentId]
WHERE [e0].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t1] ON [e.BaseReferenceOnBase.NestedCollection].[ParentReferenceId] = [t1].[Id]
WHERE [e.BaseReferenceOnBase.NestedCollection].[Discriminator] IN ('NestedCollectionDerived', 'NestedCollectionBase')
ORDER BY [t1].[Id]");
}
public override void Nested_include_with_inheritance_reference_collection3()
{
base.Nested_include_with_inheritance_reference_collection3();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name]
FROM [BaseInheritanceRelationshipEntity] AS [e]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase].*
FROM [BaseReferenceOnBase] AS [e.BaseReferenceOnBase]
WHERE [e.BaseReferenceOnBase].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t] ON [e].[Id] = [t].[BaseParentId]
WHERE [e].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
ORDER BY [t].[Id]",
//
@"SELECT [e.BaseReferenceOnBase.NestedCollection].[Id], [e.BaseReferenceOnBase.NestedCollection].[Discriminator], [e.BaseReferenceOnBase.NestedCollection].[Name], [e.BaseReferenceOnBase.NestedCollection].[ParentCollectionId], [e.BaseReferenceOnBase.NestedCollection].[ParentReferenceId]
FROM [NestedCollectionBase] AS [e.BaseReferenceOnBase.NestedCollection]
INNER JOIN (
SELECT DISTINCT [t0].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e0]
LEFT JOIN (
SELECT [e.BaseReferenceOnBase0].*
FROM [BaseReferenceOnBase] AS [e.BaseReferenceOnBase0]
WHERE [e.BaseReferenceOnBase0].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t0] ON [e0].[Id] = [t0].[BaseParentId]
WHERE [e0].[Discriminator] = 'DerivedInheritanceRelationshipEntity'
) AS [t1] ON [e.BaseReferenceOnBase.NestedCollection].[ParentReferenceId] = [t1].[Id]
WHERE [e.BaseReferenceOnBase.NestedCollection].[Discriminator] IN ('NestedCollectionDerived', 'NestedCollectionBase')
ORDER BY [t1].[Id]");
}
public override void Nested_include_with_inheritance_reference_collection_reverse()
{
base.Nested_include_with_inheritance_reference_collection_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[ParentCollectionId], [e].[ParentReferenceId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name], [t0].[Id], [t0].[Discriminator], [t0].[Name], [t0].[BaseId]
FROM [NestedCollectionBase] AS [e]
LEFT JOIN (
SELECT [e.ParentReference].*
FROM [BaseReferenceOnBase] AS [e.ParentReference]
WHERE [e.ParentReference].[Discriminator] IN ('DerivedReferenceOnBase', 'BaseReferenceOnBase')
) AS [t] ON [e].[ParentReferenceId] = [t].[Id]
LEFT JOIN (
SELECT [e.ParentReference.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.ParentReference.BaseParent]
WHERE [e.ParentReference.BaseParent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t0] ON [t].[BaseParentId] = [t0].[Id]
WHERE [e].[Discriminator] IN ('NestedCollectionDerived', 'NestedCollectionBase')");
}
public override void Nested_include_with_inheritance_collection_reference1()
{
base.Nested_include_with_inheritance_collection_reference1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
ORDER BY [e].[Id]",
//
@"SELECT [e#BaseCollectionOnBase].[Id], [e#BaseCollectionOnBase].[BaseParentId], [e#BaseCollectionOnBase].[Discriminator], [e#BaseCollectionOnBase].[Name], [e#BaseCollectionOnBase].[DerivedProperty], [t].[Id], [t].[Discriminator], [t].[Name], [t].[ParentCollectionId], [t].[ParentReferenceId]
FROM [BaseCollectionOnBase] AS [e#BaseCollectionOnBase]
LEFT JOIN (
SELECT [b.NestedReference].*
FROM [NestedReferenceBase] AS [b.NestedReference]
WHERE [b.NestedReference].[Discriminator] IN ('NestedReferenceDerived', 'NestedReferenceBase')
) AS [t] ON [e#BaseCollectionOnBase].[Id] = [t].[ParentCollectionId]
INNER JOIN (
SELECT [e0].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e0]
WHERE [e0].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t0] ON [e#BaseCollectionOnBase].[BaseParentId] = [t0].[Id]
WHERE [e#BaseCollectionOnBase].[Discriminator] IN ('DerivedCollectionOnBase', 'BaseCollectionOnBase')
ORDER BY [t0].[Id]");
}
public override void Nested_include_with_inheritance_collection_reference_reverse()
{
base.Nested_include_with_inheritance_collection_reference_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[ParentCollectionId], [e].[ParentReferenceId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name], [t].[DerivedProperty], [t0].[Id], [t0].[Discriminator], [t0].[Name], [t0].[BaseId]
FROM [NestedReferenceBase] AS [e]
LEFT JOIN (
SELECT [e.ParentCollection].*
FROM [BaseCollectionOnBase] AS [e.ParentCollection]
WHERE [e.ParentCollection].[Discriminator] IN ('DerivedCollectionOnBase', 'BaseCollectionOnBase')
) AS [t] ON [e].[ParentCollectionId] = [t].[Id]
LEFT JOIN (
SELECT [e.ParentCollection.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.ParentCollection.BaseParent]
WHERE [e.ParentCollection.BaseParent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t0] ON [t].[BaseParentId] = [t0].[Id]
WHERE [e].[Discriminator] IN ('NestedReferenceDerived', 'NestedReferenceBase')");
}
public override void Nested_include_with_inheritance_collection_collection1()
{
base.Nested_include_with_inheritance_collection_collection1();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[BaseId]
FROM [BaseInheritanceRelationshipEntity] AS [e]
WHERE [e].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
ORDER BY [e].[Id]",
//
@"SELECT [e#BaseCollectionOnBase].[Id], [e#BaseCollectionOnBase].[BaseParentId], [e#BaseCollectionOnBase].[Discriminator], [e#BaseCollectionOnBase].[Name], [e#BaseCollectionOnBase].[DerivedProperty]
FROM [BaseCollectionOnBase] AS [e#BaseCollectionOnBase]
INNER JOIN (
SELECT [e0].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e0]
WHERE [e0].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t] ON [e#BaseCollectionOnBase].[BaseParentId] = [t].[Id]
WHERE [e#BaseCollectionOnBase].[Discriminator] IN ('DerivedCollectionOnBase', 'BaseCollectionOnBase')
ORDER BY [t].[Id], [e#BaseCollectionOnBase].[Id]",
//
@"SELECT [e.BaseCollectionOnBase.NestedCollection].[Id], [e.BaseCollectionOnBase.NestedCollection].[Discriminator], [e.BaseCollectionOnBase.NestedCollection].[Name], [e.BaseCollectionOnBase.NestedCollection].[ParentCollectionId], [e.BaseCollectionOnBase.NestedCollection].[ParentReferenceId]
FROM [NestedCollectionBase] AS [e.BaseCollectionOnBase.NestedCollection]
INNER JOIN (
SELECT DISTINCT [e.BaseCollectionOnBase0].[Id], [t0].[Id] AS [Id0]
FROM [BaseCollectionOnBase] AS [e.BaseCollectionOnBase0]
INNER JOIN (
SELECT [e1].[Id]
FROM [BaseInheritanceRelationshipEntity] AS [e1]
WHERE [e1].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t0] ON [e.BaseCollectionOnBase0].[BaseParentId] = [t0].[Id]
WHERE [e.BaseCollectionOnBase0].[Discriminator] IN ('DerivedCollectionOnBase', 'BaseCollectionOnBase')
) AS [t1] ON [e.BaseCollectionOnBase.NestedCollection].[ParentCollectionId] = [t1].[Id]
WHERE [e.BaseCollectionOnBase.NestedCollection].[Discriminator] IN ('NestedCollectionDerived', 'NestedCollectionBase')
ORDER BY [t1].[Id0], [t1].[Id]");
}
public override void Nested_include_with_inheritance_collection_collection_reverse()
{
base.Nested_include_with_inheritance_collection_collection_reverse();
AssertSql(
@"SELECT [e].[Id], [e].[Discriminator], [e].[Name], [e].[ParentCollectionId], [e].[ParentReferenceId], [t].[Id], [t].[BaseParentId], [t].[Discriminator], [t].[Name], [t].[DerivedProperty], [t0].[Id], [t0].[Discriminator], [t0].[Name], [t0].[BaseId]
FROM [NestedCollectionBase] AS [e]
LEFT JOIN (
SELECT [e.ParentCollection].*
FROM [BaseCollectionOnBase] AS [e.ParentCollection]
WHERE [e.ParentCollection].[Discriminator] IN ('DerivedCollectionOnBase', 'BaseCollectionOnBase')
) AS [t] ON [e].[ParentCollectionId] = [t].[Id]
LEFT JOIN (
SELECT [e.ParentCollection.BaseParent].*
FROM [BaseInheritanceRelationshipEntity] AS [e.ParentCollection.BaseParent]
WHERE [e.ParentCollection.BaseParent].[Discriminator] IN ('DerivedInheritanceRelationshipEntity', 'BaseInheritanceRelationshipEntity')
) AS [t0] ON [t].[BaseParentId] = [t0].[Id]
WHERE [e].[Discriminator] IN ('NestedCollectionDerived', 'NestedCollectionBase')");
}
public override void Nested_include_collection_reference_on_non_entity_base()
{
base.Nested_include_collection_reference_on_non_entity_base();
AssertSql(
@"SELECT [e].[Id], [e].[Name]
FROM [ReferencedEntity] AS [e]
ORDER BY [e].[Id]",
//
@"SELECT [e.Principals].[Id], [e.Principals].[Name], [e.Principals].[ReferenceId], [e.Principals].[ReferencedEntityId], [p.Reference].[Id], [p.Reference].[Name]
FROM [PrincipalEntity] AS [e.Principals]
LEFT JOIN [ReferencedEntity] AS [p.Reference] ON [e.Principals].[ReferenceId] = [p.Reference].[Id]
INNER JOIN (
SELECT [e0].[Id]
FROM [ReferencedEntity] AS [e0]
) AS [t] ON [e.Principals].[ReferencedEntityId] = [t].[Id]
ORDER BY [t].[Id]");
}
private void AssertSql(params string[] expected)
=> Fixture.TestSqlLoggerFactory.AssertSql(expected);
private void AssertContains(params string[] expected)
=> Fixture.TestSqlLoggerFactory.AssertContains(expected);
}
}