InheritanceMappingAttribute Klas

Definitie

Wijst een overnamehiërarchie in een LINQ toe aan een SQL-toepassing.

public ref class InheritanceMappingAttribute sealed : Attribute
[System.AttributeUsage(System.AttributeTargets.Class, AllowMultiple=true, Inherited=false)]
public sealed class InheritanceMappingAttribute : Attribute
[<System.AttributeUsage(System.AttributeTargets.Class, AllowMultiple=true, Inherited=false)>]
type InheritanceMappingAttribute = class
    inherit Attribute
Public NotInheritable Class InheritanceMappingAttribute
Inherits Attribute
Overname
InheritanceMappingAttribute
Kenmerken

Voorbeelden

In dit voorbeeld ziet u overnametoewijzing voor een hiërarchie waarin de bovenste, toegewezen klasse (Shape) abstract is.

public enum ShapeType
{
    Square = 0, Circle = 1
}
[Table(Name = "Shape")]
[InheritanceMapping(Code = ShapeType.Square, Type = typeof(Square),
    IsDefault = true)]
[InheritanceMapping(Code = ShapeType.Circle, Type = typeof(Circle))]

abstract public class Shape
{
    [Column(IsDiscriminator = true)]
    public ShapeType ShapeType = 0;
}

public class Square : Shape
{
    [Column]
    public int Side = 0;
}
public class Circle : Shape
{
    [Column]
    public int Radius = 0;
}
Public Enum ShapeType As Integer
    Square = 0
    Circle = 1
End Enum

<Table(Name:="Shape")> _
<InheritanceMapping(Code:=ShapeType.Square, Type:=GetType(Square), _
    IsDefault:=True)> _
<InheritanceMapping(Code:=ShapeType.Circle, Type:=GetType(Circle))> _
Public MustInherit Class Shape
    <Column(IsDiscriminator:=True)> _
        Public ShapeType As ShapeType = 0
End Class

Public Class Square
    Inherits Shape
    <Column()> _
    Public Side As Integer = 0
End Class

Public Class Circle
    Inherits Shape
    <Column()> _
    Public Radius As Integer = 0
End Class

In het volgende voorbeeld ziet u de opname van niet-toegewezen klassen. U kunt niet-toegewezen klassen overal in de hiërarchie plaatsen.

// Unmapped and not queryable.
class A {  }

// Mapped and queryable.
[Table]
[InheritanceMapping(Code = "B", Type = typeof(B),
IsDefault = true)]
[InheritanceMapping(Code = "D", Type = typeof(D))]
class B: A {  }

// Unmapped and not queryable.
class C: B {  }

// Mapped and queryable.
class D: C {  }

// Unmapped and not queryable.
class E: D {  }
' Unmapped and not queryable.
Class A
End Class

' Mapped and queryable.
<Table()> _
<InheritanceMapping(Code:="B", Type:=GetType(B), _
IsDefault:=True)> _
<InheritanceMapping(Code:="D", Type:=GetType(D))> _
Class B
    Inherits A
End Class

' Unmapped and not queryable.
Class C
    Inherits B
End Class

' Mapped and queryable.
Class D
    Inherits C
End Class

' Unmapped and not queryable.
Class E
    Inherits D
End Class

Opmerkingen

Er wordt één InheritanceMappingAttribute opgegeven per toegewezen klasse.

Let op het volgende wanneer u overnamehiërarchieën toe wijzen:

  • Alle klassen in een hiërarchie moeten worden toegewezen aan één tabel.

  • De tabel voor een overnamehiërarchie moet worden gedeclareerd op het toegewezen type dat zich boven aan de hiërarchie bevindt. U kunt de tabel- of toewijzingskenmerken niet opgeven in een klasse die is afgeleid van de topklasse.

  • U kunt een interface in een hiërarchie gebruiken, maar LINQ wijst deze niet toe.

  • U kunt een klasse in de hiërarchie overslaan wanneer u klassen toe wijzen, maar u kunt alleen query's uitvoeren op toegewezen klassen.

Voor de juiste materialisatie moeten de codewaarden van de discriminator uniek zijn en overeenkomen met de waarden in de database. Een rij met een discriminatorcodewaarde die niet exact overeenkomt (zelfs door casing) instantiëert de klasse met behulp van IsDefault ingesteld op true.

Constructors

Name Description
InheritanceMappingAttribute()

Initialiseert een nieuw exemplaar van de InheritanceMappingAttribute klasse.

Eigenschappen

Name Description
Code

Hiermee haalt u de discriminatorcodewaarde op in een toegewezen overnamehiërarchie of stelt u deze in.

IsDefault

Hiermee wordt opgehaald of ingesteld of een object van dit type wordt geïnstantieerd wanneer de discriminatorwaarde niet overeenkomt met een opgegeven waarde.

Type

Hiermee haalt u het type van de klasse in de hiërarchie op of stelt u deze in.

TypeId

Wanneer deze wordt geïmplementeerd in een afgeleide klasse, krijgt u Attributehiervoor een unieke id.

(Overgenomen van Attribute)

Methoden

Name Description
Equals(Object)

Retourneert een waarde die aangeeft of dit exemplaar gelijk is aan een opgegeven object.

(Overgenomen van Attribute)
GetHashCode()

Retourneert de hash-code voor dit exemplaar.

(Overgenomen van Attribute)
GetType()

Hiermee haalt u de Type huidige instantie op.

(Overgenomen van Object)
IsDefaultAttribute()

Wanneer deze wordt overschreven in een afgeleide klasse, geeft u aan of de waarde van dit exemplaar de standaardwaarde is voor de afgeleide klasse.

(Overgenomen van Attribute)
Match(Object)

Wanneer deze wordt overschreven in een afgeleide klasse, wordt een waarde geretourneerd die aangeeft of dit exemplaar gelijk is aan een opgegeven object.

(Overgenomen van Attribute)
MemberwiseClone()

Hiermee maakt u een ondiepe kopie van de huidige Object.

(Overgenomen van Object)
ToString()

Retourneert een tekenreeks die het huidige object vertegenwoordigt.

(Overgenomen van Object)

Expliciete interface-implementaties

Name Description
_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Hiermee wordt een set namen toegewezen aan een bijbehorende set verzend-id's.

(Overgenomen van Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Hiermee haalt u de typegegevens voor een object op, die kan worden gebruikt om de typegegevens voor een interface op te halen.

(Overgenomen van Attribute)
_Attribute.GetTypeInfoCount(UInt32)

Hiermee wordt het aantal type-informatieinterfaces opgehaald dat een object biedt (0 of 1).

(Overgenomen van Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Biedt toegang tot eigenschappen en methoden die door een object worden weergegeven.

(Overgenomen van Attribute)

Van toepassing op