SmartSql 希望 开发人员更多的接触 Sql ,获得绝对的控制权与安全感。所以目前没有计划支持 Code First 编程模式。
我想好了Sql怎么写,然后再来写Linq,完了可能还要再查看一下Linq输出的Sql是什么样的,这真是糟糕的体验。要想对Sql做绝对的优化,那么开发者必须对Sql有绝对的控制权。另外Sql本身很简单,为何要增加一层翻译器呢?
Codefirst 一个美好,却不切实际的想法。
请阅读示例项目:https://github.com/Ahoo-Wang/SmartSql-Starter
只要是实现了ADO.NET的数据库驱动的数据库均支持,您只需要安装好对应的驱动即可。
支持,可以通过配置引入多个数据库实例:
var sqlServerMapper = MapperContainer.Instance.GetSqlMapper("SmartSqlMapConfig-SqlServer.xml");
var mySqlMapepr = MapperContainer.Instance.GetSqlMapper("SmartSqlMapConfig-MySql.xml");
SmartSql的性能与Dapper是保存同一级别的≈原生手写(另外多个其他ORM在自己的测试报告中写明比Dapper性能还高,请同学们保持好奇),文档中的 SmartSql 性能对比测试报告是开放了源代码的,任何对于性能感兴趣的同学均可以clone源代码自己跑一遍性能测试。自己Run的性能测试才是真的测试!
SmartSql 已历经1年多的线上数十个微服务场景验证,其性能、可用性、生产力是得到验证的。
作者还开源了一个代码生成器项目:SmartCode: https://github.com/Ahoo-Wang/SmartCode ,可以使用SmartCode生成解决方案,包括所有CURD操作的XML/Entity/IRepository!
Xml 的标签语法用起来会比较灵活. 比如 筛选标签,嵌套复用,可读性. 复杂查询场景用起来会非常舒爽,可读性也会比较好,代码层面不需要做任何处理,全部交给Xml .
SmartSql提供了Redis缓存插件,可通过NuGet安装:
Install-Package SmartSql.Cache.Redis
SmartSql 提供了 ZooKeeper配置插件,通过NuGet安装:
Install-Package SmartSql.ZooKeeperConfig
- 另外作者还开源了ZooKeeper节点管理工具:ZooKeeper-Admin,可直接通过该管理工具直接配置. 关于ZooKeeper-Admin:
- 使用 Asp.net Core 编写
- Docker安装:
docker pull ahoowang/zookeeper.admin
docker run --name zooAdmin -p 80:80 ahoowang/zookeeper.admin
- 本地安装
git clone https://github.com/Ahoo-Wang/ZooKeeper-Admin.git
dotnet run
是的,SmartSql编程模型多处借鉴了MyBatis,如果你之前使用过MyBatis,那么SmartSql将是你更好的选择,因为你几乎不需要有任何编程方式的转变就可以直接上手,并且拥有跨平台,高性能,以及众多你插件的支持.