SimpleNet.Standard.Data
2.0.3
dotnet add package SimpleNet.Standard.Data --version 2.0.3
NuGet\Install-Package SimpleNet.Standard.Data -Version 2.0.3
<PackageReference Include="SimpleNet.Standard.Data" Version="2.0.3" />
paket add SimpleNet.Standard.Data --version 2.0.3
#r "nuget: SimpleNet.Standard.Data, 2.0.3"
// Install SimpleNet.Standard.Data as a Cake Addin #addin nuget:?package=SimpleNet.Standard.Data&version=2.0.3 // Install SimpleNet.Standard.Data as a Cake Tool #tool nuget:?package=SimpleNet.Standard.Data&version=2.0.3
SimpleNet.Standard
SimpleNet.Standard.Data is a .NET Standard implementation of a DAL (Data Access Layer) with the hopes of simlifying execution of SQL Statements.
SimpleNet.Standard.Data.SqlServer
An implementation of ISimpleDatabaseProvider for SQL Server databases.
How To
Include SimpleNet.Standard.Data and SimpleNet.Standard.Data.SqlServer in your project
Create an instance of ISimpleDatabaseProvider ()
var dbProvider = new SqlServerProvider("Your SQL server Connection String"); var dbProvider = new PostgresSqlProvider("Your connection string"); --- Yes! I know spelling error!!
- Create an instance of ISimpleDataAccessLayer
var dal = new SimpleDataAccessLayer(dbProvider);
- Execute SQL statements
dal.ExecuteNonQuery (
"UPDATE Table SET Col1=@param1 WHERE Id = @Id ",
CommandType.Text,
new []{
dbProvider.GetParameter("@param1", someValue) ,
dbProvider.GetParameter("@id", someId)
});
dal.ExecuteScalar (
"SELECT SomeValue FROM TABLE WHERE Id = @Id ",
CommandType.Text,
new []{
dbProvider.GetParameter("@id", someId)
});
- Selecting records from the database?
We prefer working with objects instead of datatables, to enable this functionality we require and implementation of IRowMapper<T> to be provided when we Read data. We are using the IRowMapper implementation as originally implemented by Enterprise Library's Data Access Block
```
const string SQL = @"SELECT Id, Code, Name FROM STATE s where s.Id = @Id";
var records = dal.Read<State>(StateMapper, SQL, CommandType.Text, new[]
{
dbProvider.GetDbParameter("@Id", id)
});
```
IRowMapper<T> Examples
Note: Please review documentation from Enterprise Libary Data Access Block to Find out more about IRowMapper
// Map all properties on the object.
private static readonly IRowMapper<State> StateMapper = MapBuilder<State>.BuildAllProperties();
// Map all properties by name ... override how we map name
private static readonly IRowMapper<State> StateRowMapper = MapBuilder<State>
.MapAllProperties()
.Map(x => x.Name).WithFunc(x => x["Name"].ToString())
.Build();
// Manually map some/all properties
private static readonly IRowMapper<State> StateRowMapper2 = MapBuilder<State>
.MapNoProperties()
.MapByName(x => x.Id)
.Map(x => x.Code).ToColumn("Code")
.Map(x => x.Name).WithFunc(x => x["Name"].ToString())
.Build();
Working with IRepository<T> and AbstractSimpleRepository
- Create a BaseRepository that extends AbstractSimpleRepository
public class BaseSqlRepository : AbstractSimpleRepository
{
public override sealed ISimpleDataAccessLayer Database { get; set; }
public BaseSqlRepository()
{
var dbProvider = new SqlServerProvider("Your SQL server Connection String");
Database = new SimpleDataAccessLayer(dbProvider);
}
}
- Create your Repository class by extending BaseSqlRepository
public class StateRepository : BaseSqlRepository, IStateRepository
{
// Please review documentation from Enterprise Libary Db Accessors to Find out more about IRowMapper
private static readonly IRowMapper<State> StateMapper = MapBuilder<State>.BuildAllProperties();
// sample 2
private static readonly IRowMapper<State> StateRowMapper = MapBuilder<State>.MapAllProperties().Build();
// sample 3 for mapping
private static readonly IRowMapper<State> StateRowMapper2 = MapBuilder<State>
.MapNoProperties()
.MapByName(x => x.Id)
.Map(x => x.Code).ToColumn("Code")
.Map(x => x.Name).WithFunc(x => x["Name"].ToString())
.Build();
public State GetById(int id)
{
const string SQL = @"SELECT Id, Code, Name FROM STATE s where s.Id = @Id";
return Read<State>(StateMapper, SQL, CommandType.Text, new[]
{
GetDbParameter("@Id", id)
}).FirstOrDefault();
}
public State GetAll(int id)
{
const string SQL = @"SELECT Id, Code, Name FROM STATE s ORDER BY s.Name ";
return Read<State>(StateMapper, SQL, CommandType.Text, null).FirstOrDefault();
}
public DataTable ReadById(int id)
{
const string SQL = @"SELECT Id, Code, Name FROM STATE s where s.Id = @Id";
return Read(SQL, CommandType.Text, new[]
{
GetDbParameter("@Id", id)
});
}
public State Create(State state)
{
const string SQL = @"INSERT INTO STATE (Code, Name)
VALUES (@Code, @Name);
SELECT SCOPE_IDENTITY()
";
var id = ExecuteScalar(SQL, CommandType.Text, new[]
{
GetDbParameter("@Code", state.Code),
GetDbParameter("@Name", state.Name)
});
state.Id = Convert.ToInt32(id);
return state;
}
public State Update(State state)
{
const string SQL = @" UPDATE STATE
SET Code = @Code,
Name = @Name
WHERE Id = @Id
";
var id = ExecuteNonQuery(SQL, CommandType.Text, new[]
{
GetDbParameter("@Code", state.Code),
GetDbParameter("@Name", state.Name),
GetDbParameter("@Id", state.Id)
});
return state;
}
}
Working with database transactions
using (var connection = dal.GetConnection())
{
using (var transaction = connection.BeginTransaction())
{
try{
dal.ExecuteNonQuery(connection, ..... , transaction);
...
dal.ExecuteScalar(connection, ..... , transaction);
...
transaction.Commit();
}catch(){
transaction.Rollback();
}
}
}
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. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.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
- Microsoft.Data.SqlClient (>= 5.2.2)
- System.ComponentModel.TypeConverter (>= 4.3.0)
- System.Data.Common (>= 4.3.0)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on SimpleNet.Standard.Data:
Package | Downloads |
---|---|
SimpleNet.Standard.Data.SqlServer
MSSQL Connection Provider for SimpleNet.Standard.Data ADO.NET Data Access Layer Object Mapper for the .NET Framework, supports (.NET Core 2.0, .NET Standard 2.0 [PCL], .NET Framework 4.6) |
|
SimpleNet.Standard.Data.PostgresSql
PostgresSQL Connection Provider for SimpleNet.Standard.Data ADO.NET Data Access Layer Object Mapper for the .NET Framework, supports (.NET Core 2.0, .NET Standard 2.0 [PCL], .NET Framework 4.6) |
GitHub repositories
This package is not used by any popular GitHub repositories.