zoukankan      html  css  js  c++  java
  • SmartSql 常见问题

    常见问题

    为什么不支持 Linq?

    SmartSql 希望 开发人员更多的接触 Sql ,获得绝对的控制权与安全感。所以目前没有计划支持 Code First 编程模式。

    我想好了Sql怎么写,然后再来写Linq,完了可能还要再查看一下Linq输出的Sql是什么样的,这真是糟糕的体验。要想对Sql做绝对的优化,那么开发者必须对Sql有绝对的控制权。另外Sql本身很简单,为何要增加一层翻译器呢?

    Codefirst 一个美好,却不切实际的想法。

    对SmartSql很感兴趣,不知从何开始?

    请阅读示例项目:https://github.com/Ahoo-Wang/SmartSql-Starter

    SmartSql支持哪些数据库?

    只要是实现了ADO.NET的数据库驱动的数据库均支持,您只需要安装好对应的驱动即可。

    SmartSql是否支持多数据库?

    支持,可以通过配置引入多个数据库实例:

    var sqlServerMapper = MapperContainer.Instance.GetSqlMapper("SmartSqlMapConfig-SqlServer.xml");
    var mySqlMapepr = MapperContainer.Instance.GetSqlMapper("SmartSqlMapConfig-MySql.xml");
    

    SmartSql性能如何?

    SmartSql的性能与Dapper是保存同一级别的≈原生手写(另外多个其他ORM在自己的测试报告中写明比Dapper性能还高,请同学们保持好奇),文档中的 SmartSql 性能对比测试报告是开放了源代码的,任何对于性能感兴趣的同学均可以clone源代码自己跑一遍性能测试。自己Run的性能测试才是真的测试!

    SmartSql可用性如何?

    SmartSql 已历经1年多的线上数十个微服务场景验证,其性能、可用性、生产力是得到验证的。另外SmartSql已入选微软官方推荐的awesome(https://github.com/quozd/awesome-dotnet#orm)。

    对于简单CURD配置

    作者还开源了一个代码生成器项目:SmartCode: https://github.com/Ahoo-Wang/SmartCode ,可以使用SmartCode生成解决方案,包括所有CURD操作的XML/Entity/IRepository!

    为什么选择Xml作为配置语法

    Xml 的标签语法用起来会比较灵活. 比如 筛选标签,嵌套复用,可读性.
    复杂查询场景用起来会非常舒爽,可读性也会比较好,代码层面不需要做任何处理,全部交给Xml .

    集群场景如何使用获得缓存一致性

    SmartSql提供了Redis缓存插件,可通过NuGet安装:

    Install-Package SmartSql.Cache.Redis
    

    集群场景中Sql配置很多Copy怎么办

    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
    

    我之前使用过MyBatis,感觉SmartSql有种似曾相识的感觉

    是的,SmartSql编程模型多处借鉴了MyBatis,如果你之前使用过MyBatis,那么SmartSql将是你更好的选择,因为你几乎不需要有任何编程方式的转变就可以直接上手,并且拥有跨平台,高性能,以及众多你插件的支持.

    手写Xml 很痛苦是否有智能提示

    SmartSql 提供了Xml架构文档,可以获得输入智能提示的体验:
    智能提示

  • 相关阅读:
    loadrunder之脚本篇——集合点设置
    Loadrunner之脚本篇——事务函数
    Loadrunder之脚本篇——事务时间简介
    Loadrunder之脚本篇——参数化在场景中的运用
    Java提高(一)---- HashMap
    阅读收集
    SpringMVC是什么?
    elasticsearch head安装
    Elasticsearch 全量遍历数据
    JVM 堆内存,参数优化
  • 原文地址:https://www.cnblogs.com/Ahoo-Wang/p/SmartSql-common-problem.html
Copyright © 2011-2022 走看看