Ich entwickle ASP.net-Web-API-REST-Dienste. Meine Daten werden in einer relationalen MySQL-Datenbank gespeichert. In der Datenzugriffsebene möchte ich Dapper micro ORM verwenden, also möchte ich eine Art von eigenen ORM-Wrapper-Methoden erstellen. Wenn ich mich in Zukunft dazu entscheide, zu einem anderen ORM zu wechseln, muss ich nicht meinen gesamten DAL-Layer-Code neu schreiben.Benutzerdefinierter C# Dapper ORM-Wrapper
Was denken Sie über meinen Ansatz? Hier ist der Code:
public abstract class BaseORMCommandSettings //SQL command base class
{
public string CommandText { get; private set; }
public object Parameters { get; private set; }
public IDbTransaction Transaction { get; private set; }
public int? CommandTimeout { get; private set; }
public CommandType? CommandType { get; private set; }
public CancellationToken CancellationToken { get; private set; }
public BaseORMCommandSettings(string commandText, object parameters = null, IDbTransaction transaction = null, int? commandTimeout = null,
CommandType? commandType = null, CancellationToken cancellationToken = default(CancellationToken))
{
this.CommandText = commandText;
this.Parameters = parameters;
this.Transaction = transaction;
this.CommandTimeout = commandTimeout;
this.CommandType = commandType;
this.CancellationToken = cancellationToken;
}
}
public class DapperCommandSettings : BaseORMCommandSettings//dapper cmd impl
{
public CommandFlags Flags { get; private set; }
public DapperCommandSettings(string commandText, object parameters = null, IDbTransaction transaction = null, int? commandTimeout = null,
CommandType? commandType = null, CancellationToken cancellationToken = default(CancellationToken), CommandFlags flags = CommandFlags.Buffered)
:base(commandText, parameters, transaction, commandTimeout, commandType, cancellationToken)
{
this.Flags = flags;
}
}
public interface ICustomORM //base interface, for now have only generic Read
list method
{
IEnumerable<T> Read<T>(BaseORMCommandSettings cmd);
}
public class DapperORM : ICustomORM //my own dapper ORM wrapper implentation
{
private readonly IDbConnection con;
public DapperORM(IDbConnection con)
{
this.con = con;
}
public IEnumerable<T> Read<T>(BaseORMCommandSettings cmd)
{
var cmdDapper = cmd as DapperCommandSettings;
var dapperCmd = new CommandDefinition(cmdDapper.CommandText, cmdDapper.Parameters, cmdDapper.Transaction,
cmdDapper.CommandTimeout, cmdDapper.CommandType, cmdDapper.Flags,
cmdDapper.CancellationToken);
return con.Query<T>(dapperCmd);
}
}
Vielen Dank im Voraus für jede Art von Hilfe.
[SO] nicht über Code-Review, sollten Sie vielleicht fragen, auf https://codereview.stackexchange.com/ – Richard
Danken ... für deine Antwort. Eigentlich möchte ich die Meinung von jemandem über meine Code-Implementierung hören, um Code zu schreiben, wo ich ziemlich einfach und schnell die Technologie ändern kann, die ich benutze ... Das ist also mehr über Design, nicht über Code-Review. – user2214626