经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C# » 查看文章
SmartSql For Asp.Net Core 最佳实践 - Ahoo-Wang
来源:cnblogs  作者:Ahoo-Wang  时间:2018/10/16 9:40:50  对本文有异议

常规操作

安装 SmartSql

  1. Install-Package SmartSql

安装 SmartSql.DIExtension

  1. Install-Package SmartSql.DIExtension

配置SmartSqlConfig.xml

  • 写库(Write)必选 唯一节点
  • 读库(Read)可选 多节点配置

    Postgresql

  • Postgresql 客户端 Npgsql
  1. Install-Package Npgsql
  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <SmartSqlMapConfig xmlns="http://SmartSql.net/schemas/SmartSqlMapConfig.xsd">
  3. <Settings
  4. IsWatchConfigFile="true"
  5. />
  6. <Database>
  7. <!--ParameterPrefix:[SqlServer:@ | MySQL:? |Oracle::|Postgresql:@] -->
  8. <DbProvider Name="SqlClientFactory" ParameterPrefix="@" Type="Npgsql.NpgsqlFactory,Npgsql"/>
  9. <Write Name="WriteDB" ConnectionString="Server=localhost;Port=5432;User Id=postgres;Password=Rocher2016; Database=SmartSqlDB;"/>
  10. </Database>
  11. <SmartSqlMaps>
  12. <SmartSqlMap Path="Maps/" Type="Directory"></SmartSqlMap>
  13. </SmartSqlMaps>
  14. </SmartSqlMapConfig>

MYSQL

  • 安装mysql 客户端 Mysql.Data
  1. Install-Package Mysql.Data
  • 配置SmartSqlMapConfig.xml
  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <SmartSqlMapConfig xmlns="http://SmartSql.net/schemas/SmartSqlMapConfig.xsd">
  3. <Settings IsWatchConfigFile="false" />
  4. <Database>
  5. <DbProvider Name="MySqlClientFactory" ParameterPrefix="?" Type="MySql.Data.MySqlClient.MySqlClientFactory,MySql.Data"/>
  6. <Write Name="WriteDB" ConnectionString="Data Source=.;database=SmartSqlDB;uid=SmartSql;pwd=Rocher2018;Charset=utf8;SslMode=none"/>
  7. <Read Name="ReadDB-0" ConnectionString="Data Source=.;database=SmartSqlDB-Read1;uid=SmartSql;pwd=Rocher2018;Charset=utf8;SslMode=none" Weight="80"/>
  8. <Read Name="ReadDB-1" ConnectionString="Data Source=.;database=SmartSqlDB-Read2;uid=SmartSql;pwd=Rocher2018;Charset=utf8;SslMode=none" Weight="20"/>
  9. </Database>
  10. <SmartSqlMaps>
  11. <!--两种配置方式 推荐Directory模式-->
  12. <SmartSqlMap Path="Maps" Type="Directory"></SmartSqlMap>
  13. <SmartSqlMap Path="Maps/T_User.xml" Type="File"></SmartSqlMap>
  14. </SmartSqlMaps>
  15. </SmartSqlMapConfig>

MSSQL

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <SmartSqlMapConfig xmlns="http://SmartSql.net/schemas/SmartSqlMapConfig.xsd">
  3. <Settings
  4. IsWatchConfigFile="true"
  5. />
  6. <Database>
  7. <!--ParameterPrefix:[SqlServer:@ | MySQL:? |Oracle::] -->
  8. <DbProvider Name="SqlClientFactory" ParameterPrefix="@" Type="System.Data.SqlClient.SqlClientFactory,System.Data.SqlClient"/>
  9. <Write Name="WriteDB" ConnectionString="Data Source=.;database=SmartSqlDB;uid=SmartSql;pwd=Rocher2018"/>
  10. <Read Name="ReadDB-1" ConnectionString="Data Source=.;database=SmartSqlDB-Read1;uid=SmartSql;pwd=Rocher2018"/>
  11. <Read Name="ReadDB-2" ConnectionString="Data Source=.;database=SmartSqlDB-Read2;uid=SmartSql;pwd=Rocher2018"/>
  12. </Database>
  13. <SmartSqlMaps>
  14. <SmartSqlMap Path="Maps" Type="Directory"></SmartSqlMap>
  15. </SmartSqlMaps>
  16. </SmartSqlMapConfig>

注入依赖

  1. services.AddSmartSql();
  2. services.AddRepositoryFactory();
  3. services.AddRepositoryFromAssembly((options) =>
  4. {
  5. options.AssemblyString = "SmartSql.Starter.Repository";
  6. });

定义仓储接口

  1. /// <summary>
  2. /// 属性可选: [SqlMap(Scope = "User")] ,不设置 则默认 Scope 模板:I{Scope}Repository
  3. /// 可传入自定义模板
  4. /// RepositoryBuilder builder=new RepositoryBuilder("I{Scope}DAL");
  5. /// </summary>
  6. public interface IUserRepository
  7. {
  8. /// <summary>
  9. /// 属性可选 [Statement(Execute = ExecuteBehavior.Auto,Id = "Query")]
  10. /// 默认 Execute:Auto ,自动判断 执行类型
  11. /// 默认 Id : 方法名
  12. /// </summary>
  13. /// <param name="reqParams"></param>
  14. /// <returns></returns>
  15. IEnumerable<User> Query(object reqParams);
  16. long GetRecord(object reqParams);
  17. User Get(object reqParams);
  18. long Insert(User entity);
  19. int Update(User entity);
  20. int Delete(User entity);
  21. }

尽情享用

  1. public class UserService
  2. {
  3. private readonly ISmartSqlMapper _smartSqlMapper;
  4. private readonly IUserRepository _userRepository;
  5. public UserService(
  6. ISmartSqlMapper smartSqlMapper
  7. , IUserRepository userRepository)
  8. {
  9. _smartSqlMapper = smartSqlMapper;
  10. _userRepository = userRepository;
  11. }
  12. public long Add(AddRequest request)
  13. {
  14. int existsNum = _userRepository.Exists(new { request.UserName });
  15. if (existsNum > 0)
  16. {
  17. throw new ArgumentException($"{nameof(request.UserName)} has already existed!");
  18. }
  19. return _userRepository.Add(new Entitiy.User
  20. {
  21. UserName = request.UserName,
  22. Password = request.Password,
  23. Status = Entitiy.UserStatus.Ok,
  24. CreationTime = DateTime.Now,
  25. });
  26. }
  27. public void UseTransaction()
  28. {
  29. try
  30. {
  31. _smartSqlMapper.BeginTransaction();
  32. //Biz();
  33. _smartSqlMapper.CommitTransaction();
  34. }
  35. catch (Exception ex)
  36. {
  37. _smartSqlMapper.RollbackTransaction();
  38. throw ex;
  39. }
  40. }
  41. }
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号