SmartSql For Asp.Net Core 最佳实践

本文介绍了SmartSql的安装配置方法及其在不同数据库环境下的应用案例,包括PostgreSQL、MySQL和MSSQL,并展示了如何通过.NET Core进行依赖注入及定义仓储接口。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SmartSql 最佳实践

常规操作

安装 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;
            }
        }
    }
<think>好的,用户想要寻找C#相关的开源项目推荐。我之前已经整理过一些相关的信息,现在需要根据提供的引用资料来生成合适的回答。首先,需要确认用户的需求是寻找实用或流行的C#开源项目,可能用于学习、开发或者工具使用。 引用中提到几个项目:NPlot是图表库,wx.NET是GUI库,还有SmartSQL作为数据库工具。此外,用户之前的问题可能涉及这些项目,所以需要结合之前的回答。需要确保推荐的项目涵盖不同领域,比如GUI开发、图表生成、数据库工具等,这样能满足不同用户的需求。 用户可能需要每个项目的简要介绍、特点和适用场景。同时,按照系统级指令,回答必须结构清晰,分点说明。另外,根据用户之前的引用,可能还需要补充其他常见的C#开源项目,比如ASP.NET Core、Entity Framework Core等,但这些不在提供的引用中,所以可能需要仅根据现有引用进行推荐。 需要检查引用中的信息是否足够。引用1提到NPlot的API设计和多平台控件;引用2介绍wx.NET是基于wxWidgets的GUI库;引用4提到SmartSQL的多数据库支持。此外,引用3提到C#在Windows生态中的地位,可能需要强调这些项目在Windows环境下的实用性。 接下来需要组织回答结构:首先分点推荐项目,每个项目包括简介、特点和适用场景。然后生成相关问题。确保使用正确的中文表达,并符合LaTeX格式要求,但问题中没有数学公式,所以可能不需要使用$符号。最后,添加引用标识在对应的段落末尾。 需要确保每个推荐项目都有对应的引用来源,并且正确标注。例如,NPlot对应引用1,wx.NET对应引用2,SmartSQL对应引用4。引用3是总体介绍C#的地位,可能用于开头或结尾的总结部分。 最后,生成的相关问题需要与推荐项目相关,比如询问GUI库选择、图表工具比较或数据库工具功能等。确保问题具有实际意义,帮助用户进一步探索。</think>根据您的需求,我将推荐几个值得关注的C#开源项目,并结合实际应用场景进行分析: ### 一、GUI开发框架 1. **wx.NET** 基于wxWidgets的跨平台GUI库,支持.NET/Mono等环境,提供Windows、Linux、macOS多平台原生控件支持。其类层次结构与wxWidgets一致,适合需要跨平台桌面应用开发的场景[^2]。 ```csharp // 示例:创建基础窗口 var app = new wx.App(); var frame = new wx.Frame(null, wx.Window.ID_ANY, "Hello World"); frame.Show(true); app.MainLoop(); ``` 2. **AvaloniaUI** 虽然未直接提及,但作为现代化跨平台XAML框架,支持Skia渲染引擎,可开发具有Material Design风格的应用程序。 ### 二、数据可视化工具 **NPlot** .NET下的开源图表库,支持WinForms、ASP.NET和位图生成。其亮点在于: - 灵活API设计:仅需3行代码生成柱状图 - 多输出格式:支持实时控件渲染和静态图片导出 - 数学计算集成:内置$y=\sin(x)$等函数快速绘图[^1] ### 三、数据库工具 **SmartSQL** 多数据库文档工具,主要特性: - 支持SqlServer/MySQL/PostgreSQL等6种数据库 - 导出格式覆盖Word/Excel/PDF/Markdown等8种格式 - 可视化查询生成器,适合DBA和开发人员管理数据库文档[^4] ### 四、企业级应用框架 **ABP Framework** 模块化应用开发框架,提供: - 领域驱动设计(DDD)实现 - 微服务架构支持 - 多租户系统构建能力 - 集成IdentityServer4身份认证
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值