SmartSql For Asp.Net Core 最佳實踐
阿新 • • 發佈:2018-11-12
常規操作
安裝 SmartSql
Install-Package SmartSql
安裝 SmartSql.DIExtension
Install-Package SmartSql.DIExtension
配置SmartSqlConfig.xml
- 寫庫(Write)必選 唯一節點
讀庫(Read)可選 多節點配置
Postgresql
- Postgresql 客戶端 Npgsql
Install-Package Npgsql
<?xml version="1.0" encoding="utf-8" ?> <SmartSqlMapConfig xmlns="http://SmartSql.net/schemas/SmartSqlMapConfig.xsd"> <Settings IsWatchConfigFile="true" /> <Database> <!--ParameterPrefix:[SqlServer:@ | MySQL:? |Oracle::|Postgresql:@] --> <DbProvider Name="SqlClientFactory" ParameterPrefix="@" Type="Npgsql.NpgsqlFactory,Npgsql"/> <Write Name="WriteDB" ConnectionString="Server=localhost;Port=5432;User Id=postgres;Password=Rocher2016; Database=SmartSqlDB;"/> </Database> <SmartSqlMaps> <SmartSqlMap Path="Maps/" Type="Directory"></SmartSqlMap> </SmartSqlMaps> </SmartSqlMapConfig>
MYSQL
- 安裝mysql 客戶端 Mysql.Data
Install-Package Mysql.Data
- 配置SmartSqlMapConfig.xml
<?xml version="1.0" encoding="utf-8" ?> <SmartSqlMapConfig xmlns="http://SmartSql.net/schemas/SmartSqlMapConfig.xsd"> <Settings IsWatchConfigFile="false" /> <Database> <DbProvider Name="MySqlClientFactory" ParameterPrefix="?" Type="MySql.Data.MySqlClient.MySqlClientFactory,MySql.Data"/> <Write Name="WriteDB" ConnectionString="Data Source=.;database=SmartSqlDB;uid=SmartSql;pwd=Rocher2018;Charset=utf8;SslMode=none"/> <Read Name="ReadDB-0" ConnectionString="Data Source=.;database=SmartSqlDB-Read1;uid=SmartSql;pwd=Rocher2018;Charset=utf8;SslMode=none" Weight="80"/> <Read Name="ReadDB-1" ConnectionString="Data Source=.;database=SmartSqlDB-Read2;uid=SmartSql;pwd=Rocher2018;Charset=utf8;SslMode=none" Weight="20"/> </Database> <SmartSqlMaps> <!--兩種配置方式 推薦Directory模式--> <SmartSqlMap Path="Maps" Type="Directory"></SmartSqlMap> <SmartSqlMap Path="Maps/T_User.xml" Type="File"></SmartSqlMap> </SmartSqlMaps> </SmartSqlMapConfig>
MSSQL
<?xml version="1.0" encoding="utf-8" ?> <SmartSqlMapConfig xmlns="http://SmartSql.net/schemas/SmartSqlMapConfig.xsd"> <Settings IsWatchConfigFile="true" /> <Database> <!--ParameterPrefix:[SqlServer:@ | MySQL:? |Oracle::] --> <DbProvider Name="SqlClientFactory" ParameterPrefix="@" Type="System.Data.SqlClient.SqlClientFactory,System.Data.SqlClient"/> <Write Name="WriteDB" ConnectionString="Data Source=.;database=SmartSqlDB;uid=SmartSql;pwd=Rocher2018"/> <Read Name="ReadDB-1" ConnectionString="Data Source=.;database=SmartSqlDB-Read1;uid=SmartSql;pwd=Rocher2018"/> <Read Name="ReadDB-2" ConnectionString="Data Source=.;database=SmartSqlDB-Read2;uid=SmartSql;pwd=Rocher2018"/> </Database> <SmartSqlMaps> <SmartSqlMap Path="Maps" Type="Directory"></SmartSqlMap> </SmartSqlMaps> </SmartSqlMapConfig>
注入依賴
services.AddSmartSql();
services.AddRepositoryFactory();
services.AddRepositoryFromAssembly((options) =>
{
options.AssemblyString = "SmartSql.Starter.Repository";
});
定義倉儲介面
/// <summary>
/// 屬性可選: [SqlMap(Scope = "User")] ,不設定 則預設 Scope 模板:I{Scope}Repository
/// 可傳入自定義模板
/// RepositoryBuilder builder=new RepositoryBuilder("I{Scope}DAL");
/// </summary>
public interface IUserRepository
{
/// <summary>
/// 屬性可選 [Statement(Execute = ExecuteBehavior.Auto,Id = "Query")]
/// 預設 Execute:Auto ,自動判斷 執行型別
/// 預設 Id : 方法名
/// </summary>
/// <param name="reqParams"></param>
/// <returns></returns>
IEnumerable<User> Query(object reqParams);
long GetRecord(object reqParams);
User Get(object reqParams);
long Insert(User entity);
int Update(User entity);
int Delete(User entity);
}
盡情享用
public class UserService
{
private readonly ISmartSqlMapper _smartSqlMapper;
private readonly IUserRepository _userRepository;
public UserService(
ISmartSqlMapper smartSqlMapper
, IUserRepository userRepository)
{
_smartSqlMapper = smartSqlMapper;
_userRepository = userRepository;
}
public long Add(AddRequest request)
{
int existsNum = _userRepository.Exists(new { request.UserName });
if (existsNum > 0)
{
throw new ArgumentException($"{nameof(request.UserName)} has already existed!");
}
return _userRepository.Add(new Entitiy.User
{
UserName = request.UserName,
Password = request.Password,
Status = Entitiy.UserStatus.Ok,
CreationTime = DateTime.Now,
});
}
public void UseTransaction()
{
try
{
_smartSqlMapper.BeginTransaction();
//Biz();
_smartSqlMapper.CommitTransaction();
}
catch (Exception ex)
{
_smartSqlMapper.RollbackTransaction();
throw ex;
}
}
}