常规操作

安装 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. }

SmartSql For Asp.Net Core 最佳实践的更多相关文章

  1. ASP.NET跨平台最佳实践

    前言 八年的坚持敌不过领导的固执,最终还是不得不阔别已经成为我第二语言的C#,转战Java阵营.有过短暂的失落和迷茫,但技术转型真的没有想象中那么难.回头审视,其实单从语言本身来看,C#确实比Java ...

  2. [转]ASP.NET MVC 4 最佳实践宝典

    原文:http://www.cnblogs.com/sonykings/archive/2013/05/30/3107531.html ASP.NET MVC最佳实践 本文档提供了一套旨在帮助创建最佳 ...

  3. ASP.NET 开发者 开始学习ASP.NET Core 2吧

    .  NET Core 从2016年6月28日发布,过去了将近一年的时间,但是在工作中发现大家对.net core的接受程度并不高,这只是一个感觉,俗话说“没有调查就没有发言权”, 这两天通过微信小程 ...

  4. 为什么 web 开发人员需要迁移到. NET Core, 并使用 ASP.NET Core MVC 构建 web 和 webservice/API

    2018 .NET开发者调查报告: .NET Core 是怎么样的状态,这里我们看到了还有非常多的.net开发人员还在观望,本文给大家一个建议.这仅代表我的个人意见, 我有充分的理由推荐.net 程序 ...

  5. ASP.NET Core 菜鸟之路:从Startup.cs说起

    1.前言 本文主要是以Visual Studio 2017 默认的 WebApi 模板作为基架,基于Asp .Net Core 1.0,本文面向的是初学者,如果你有 ASP.NET Core 相关实践 ...

  6. ASP.NET Core 菜鸟之路:从Startup.cs说起 转发https://www.cnblogs.com/chenug/p/6869109.html

    1.前言 本文主要是以Visual Studio 2017 默认的 WebApi 模板作为基架,基于Asp .Net Core 1.0,本文面向的是初学者,如果你有 ASP.NET Core 相关实践 ...

  7. ASP.NET Core on K8S 入门学习系列文章目录

    一.关于这个系列 自从2018年底离开工作了3年的M公司加入X公司之后,开始了ASP.NET Core的实践,包括微服务架构与容器化等等.我们的实践是渐进的,当我们的微服务数量到了一定值时,发现运维工 ...

  8. 【转】.NET(C#):浅谈程序集清单资源和RESX资源 关于单元测试的思考--Asp.Net Core单元测试最佳实践 封装自己的dapper lambda扩展-设计篇 编写自己的dapper lambda扩展-使用篇 正确理解CAP定理 Quartz.NET的使用(附源码) 整理自己的.net工具库 GC的前世与今生 Visual Studio Package 插件开发之自动生

    [转].NET(C#):浅谈程序集清单资源和RESX资源   目录 程序集清单资源 RESX资源文件 使用ResourceReader和ResourceSet解析二进制资源文件 使用ResourceM ...

  9. ASP.NET Core Web API 最佳实践指南

    原文地址: ASP.NET-Core-Web-API-Best-Practices-Guide 介绍 当我们编写一个项目的时候,我们的主要目标是使它能如期运行,并尽可能地满足所有用户需求. 但是,你难 ...

随机推荐

  1. Java String类的intern()方法

    该方法的作用是把字符串加载到常量池中(jdk1.6常量池位于方法区,jdk1.7以后常量池位于堆) 在jdk1.6中,该方法把字符串的值复制到常量区,然后返回常量区里这个字符串的值: 在jdk1.7里 ...

  2. 如何修改SnipeIT的部分设置

    作为一款开源的资产管理系统,Snipe-IT非常的好用又结实,但是原始设置对中国用户有些不方便,部分汉化没有完成,需要直接修改代码,下面把常用的修改记录如下: 1.修改资产打印标签中的文本名称 找到  ...

  3. NOIP2013提高组 T2 火柴排队

    一开始看也想不到这居然要用到逆序对,归并排序. 先来看看题目: 涵涵有两盒火柴,每盒装有 n 根火柴,每根火柴都有一个高度. 现在将每盒中的火柴各自排成一列, 同一列火柴的高度互不相同, 两列火柴之间 ...

  4. C#中IPAddress转换成整型int

    string addr = "11.22.33.44"; System.Net.IPAddress IPAddr=System.Net.IPAddress.Parse(addr); ...

  5. c#几种随机数组和数组乱序

    相关资料MSDN:RNGCryptoServiceProvider   Random   Guid private static RNGCryptoServiceProvider rngCsp = n ...

  6. Go smtp发送邮件,带附件

    package main import ( "net/smtp" "bytes" "time" "io/ioutil" ...

  7. /usr/lib/python2.7/site-packages/requests/__init__.py:80: RequestsDependencyWarning: urllib3 (1.22) or chardet (2.2.1) doesn't match a supported version! RequestsDependencyWarning)

    [root@iZwz9bhan5nqzh979qokrkZ ~]# ansible all -m ping /usr/lib/python2.7/site-packages/requests/__in ...

  8. R语言grid包just参数如何just图形位置

    思路   grid的画图函数都含有just,但是just参数的是怎么调节图形位置的总是让人非常费解,于是便写了代码来一探究竟.   思路非常简单:放一个2*2的布局viewport,每个布局里面放一个 ...

  9. js中的cookie

    cookie就是一个存放数据的东西,存储量很小4kb,存放在客户端上和应用设备上. 应用场景 用户注册,用户登录,购物车. Chrome浏览器在计算机中存放cookie的位置 C:\Users\Adm ...

  10. 在Linux上要安装SSH协议

    学习准备:博客园.CSDN.51CTO,注意问问题去CSDN.注意还有一种就是自己搭建博客,自己搭建博客相当于写一个网站:http://pyshell.cn;github:是一个代码仓库是别人的.有些 ...