RobinManzl.DataAccessLayer
1.7.2
See the version list below for details.
dotnet add package RobinManzl.DataAccessLayer --version 1.7.2
NuGet\Install-Package RobinManzl.DataAccessLayer -Version 1.7.2
<PackageReference Include="RobinManzl.DataAccessLayer" Version="1.7.2" />
paket add RobinManzl.DataAccessLayer --version 1.7.2
#r "nuget: RobinManzl.DataAccessLayer, 1.7.2"
// Install RobinManzl.DataAccessLayer as a Cake Addin #addin nuget:?package=RobinManzl.DataAccessLayer&version=1.7.2 // Install RobinManzl.DataAccessLayer as a Cake Tool #tool nuget:?package=RobinManzl.DataAccessLayer&version=1.7.2
Vorbereitung
Datenbank
Bevor das Framework verwendet werden kann, muss eine Datenbanktabelle erstellt werden. Das Framework geht von Tabellen mit mindestens einem Attribut aus, das mit dem PrimaryKeyAttribute als Primärschlüssel markiert wurde. Diese Spalte muss als Identitätsspalte festgelegt werden, während alle restlichen Attribute der Tabelle sind frei wählbar.
Entitätsklassen
Um die Daten einer erstellten Tabelle abfragen zu können, muss eine passende Entitätsklasse erstellt werden, wobei der Klassenname dem Tabellennamen entsprechen muss. Hierzu muss die Klasse das IEntity-Interface implementieren, wel Jede roperty, welche von der Datenbanktabelle gemappt werden soll, muss mit dem ColumnAttribut versehen werden. Hier gilt auch wieder Einschränkung, dass die Properties dieselben Namen wie die Spalten in der Tabelle besitzen müssen.
Daten abrufen
Zeilen einer Tabelle kann mit Hilfe der DbService-Klasse abgerufen werden. Diese Klasse ist generisch und erwartet als Typparameter die Entitätsklasse, welche zu der entsprechenden Tabelle passt. Mit der Methode GetEntities können die Objekte dann von der Tabelle abgerufen werden.
QueryCondition
Um die WHERE-Klausel der Abfrage anzugeben, dient die Klasse QueryCondition. Sie ist abstrakt und wird von diversen anderen Klassen geerbt. Es ist beispielsweise mit der ValueCompareCondition-Klasse möglich, die Zeilen anhand einem Wertvergleich zu filtern. Alternativ kann auch eine Expression vom Typ Func<T,bool> angegeben werden, wobei T der Entitätsklasse entspricht.
QueryOptions
Die Klasse QueryOptions dient dazu, dem DbService diverse Optionen zu übergeben. Z.B. kann angegeben werden, wie viele Zeilen maximal von der Datenbank zurückgegeben werden sollen. Die Angabe von bis zu drei Spalten für die Sortierung kann auch über diese Klasse bewerkstelligt werden.
Daten ändern
Daten können mithilfe der InsertEntity-, der UpdateEntity- und der DeleteEntity-Methoden verändert werden unter der Angabe einer Instanz der Entitätsklasse.
Besonderheiten
TableAttribute
Mit dem TableAttribute ist es möglich, die Entitätsklasse anders zu benennen, wie die zugehörige Tabelle. Zusätzlich kann noch ein Schema angegeben werden, welches die Tabelle verwendet. Bei der Verwendung des Standardschemas - dbo - kann dieses Feld ignoriert werden.
ColumnAttribute
Das ColumnAttribute bietet, ähnlich wie das TableAttribute, die Möglichkeit, einen vom Property-namen abweichenden Spaltennamen zu verwenden.
Views
Es gibt die Möglichkeit, Daten auch direkt von Views abzufragen. Hierfür existiert ein eigenes Attribut, welches anstelle des TableAttribute verwendet werden soll. Das ViewAttribute besitzt zusätzlich zum Namen der View noch Felder für die Angabe von Stored Procedures, die bei den Methoden zur Änderung von Zeilen verwendet werden. Die beiden Stored Procedures, welche für Insert- und Update-Vorgänge verwendet werden, sollten für jedes Attribut der Entitätsklasse einen entsprechenden Parameter besitzen. Die letzte Stored Procedure für Löschvorgänge hingegen sollte nur den Parameter für den Primärschlüssel besitzen.
Transaktionen
Transaktionen werden mittels den Methoden BeginTransaction und RemoveTransaction begonnen und entfernt. Das Abbrechen bzw. das Anwenden der Transaktion muss direkt mit der zurückgelieferten SqlTransaction erledigt werden. Um Transaktionen über mehrere Instanzen der DbService-Klasse zu verwenden, akzeptiert die BeginTransaction-Methode optional eine SqlTransaction.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- NLog (>= 4.5.10)
- System.Data.SqlClient (>= 4.1.0)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on RobinManzl.DataAccessLayer:
Package | Downloads |
---|---|
RobinManzl.DataAccessLayer.JsonConfiguration
Erleichtert die Konfiguration des DataAccessLayer mittels JSON-File |
|
RobinManzl.DataAccessLayer.HistoryExtension
Ermöglicht die Historisierung der Daten auf Zeilenbasis |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
3.0.13 | 670 | 7/7/2020 |
3.0.12 | 509 | 6/26/2020 |
3.0.11 | 454 | 6/18/2020 |
3.0.10 | 459 | 6/11/2020 |
3.0.9 | 519 | 4/17/2020 |
3.0.8 | 518 | 4/15/2020 |
3.0.7 | 517 | 4/8/2020 |
3.0.6 | 512 | 3/31/2020 |
3.0.5 | 498 | 3/17/2020 |
3.0.4 | 482 | 2/29/2020 |
3.0.3 | 514 | 2/27/2020 |
3.0.2 | 484 | 2/27/2020 |
3.0.1 | 754 | 2/19/2020 |
2.5.7 | 699 | 1/27/2020 |
2.5.6 | 6,161 | 1/21/2020 |
2.5.5 | 566 | 1/20/2020 |
2.5.4 | 589 | 1/19/2020 |
2.5.3 | 494 | 1/17/2020 |
2.4.1 | 549 | 1/15/2020 |
2.4.0 | 574 | 1/14/2020 |
2.3.7 | 522 | 1/10/2020 |
2.3.6 | 609 | 9/30/2019 |
2.3.5 | 519 | 9/29/2019 |
2.3.4 | 505 | 9/29/2019 |
2.3.3 | 516 | 9/29/2019 |
2.3.2 | 545 | 9/29/2019 |
2.2.5 | 515 | 9/25/2019 |
2.1.6 | 532 | 9/23/2019 |
2.1.4 | 753 | 9/19/2019 |
2.1.3 | 570 | 9/19/2019 |
2.1.2 | 582 | 7/4/2019 |
2.1.1 | 537 | 7/4/2019 |
2.0.2 | 596 | 5/6/2019 |
2.0.1 | 591 | 5/6/2019 |
1.8.1 | 613 | 2/26/2019 |
1.8.0 | 618 | 2/25/2019 |
1.7.8 | 749 | 1/14/2019 |
1.7.3 | 685 | 12/19/2018 |
1.7.2 | 664 | 12/6/2018 |
1.7.1 | 706 | 12/3/2018 |
1.7.0 | 716 | 11/13/2018 |
1.6.8 | 709 | 11/12/2018 |
1.5.3 | 761 | 10/22/2018 |
1.5.2 | 729 | 10/22/2018 |
Möglichkeit hinzugefügt, Zeilen zu überspringen (OFFSET - FETCH)