1、已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭。

There is already an open DataReader associated with this Connection which must be closed first.

或者出现 connection is closed

出现这个错一般是线程安全引起的

解决方案: https://www.donet5.com/Home/Doc?typeId=1224

2.The connection does not support MultipleActiveResultSets

(1)、SqlSugarClient 替换成 SqlSugarScope ,因为SqlSugarScope 是线程安全对象代码容错率高

具体用法: https://www.donet5.com/Home/Doc?typeId=1181

(2)  、异步用法错引起的 ,排查没用Await调用的异步方法

Public void  GetAll(){  异步方法  }//错误
Public async Task GetAll(){  异步方法  }//错误
Public async Task GetAll(){  await  异步方法  }//正确

 

 3. max_allowed_packet  MYSQL

一般提示这个错可能一次更新的内容太多,可以分页操作

db.Utilities.PageEach(allList, 10000 ,pageList=> {
  db.Insertable(pageList).ExecuteCommand();
});

4、实体与表映射出错

出现这个错一般是 数据库中的类型和实体中的类型不一样引起的,可以注释实体类中的字段进行排除哪个字段引起的

5、Only one primary key

当前功能只支持单主键,看看实体类有没有与置主键,并且主键只能有一个,或者数据库是否有主键并且只能有一个

6、未安装或者版本冲突

打开 Web层或者WinFom的项目,查看 App.config 有没有下面这种兼容配置,如果没这种配置这个DLL就会报错,

想办法搞出来,一般NUGET在当前项目安装 SqlSugar然后在安装报错的DLL NUGET会自动添加到app.config

例1:

   
      <dependentAssembly>
        <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
        <bindingRedirect oldVersion="0.0.0.0-9.0.0.0" newVersion="9.0.0.0" />
      </dependentAssembly>

例2:

  <dependentAssembly>
        <assemblyIdentity name="MySql.Data" publicKeyToken="c5687fc88969c44d" culture="neutral" />
        <bindingRedirect oldVersion="0.0.0.0-8.0.27.0" newVersion="8.0.27.0" />
   </dependentAssembly>

如果没有先安装SqlSugar,在安装报错dll

7、雪花ID重复

不同电脑 本地或者服务器 要用不同的WorkId ,如果服务器时间回调也要设置WorkId

8、Cannot Open when State is Connecting.

解决方案: https://www.donet5.com/Home/Doc?typeId=1224

9、连接不上数据库

原生能用SqlSugar就能用,一定要用db.CurrentConfig.ConnectionString保证是同一个字段串,并且在同一个程序

//用原代码进行测试
//SqlSerer 
var conn=new SqlConnection(db.CurrentConfig.ConnectionString).Open();
conn.Close();
 
//MySql用
var conn=new MySqlConnection(db.CurrentConfig.ConnectionString).Open();
conn.Close();
 
//不同的数据库不同 ,一般根据DbType+Connection

10、截断二进制

Data too long for column

数据库字段太小引起的

11、特殊表字段名带有.或者()这字符兼容

因为考虑性能,比如数据库里面字段名字叫: 金额(元) ,生在SQL如下 where [金额(元)]=@金额(元) ,字段能转译参数名做不到所有都过滤,

这样参名字会报错,所以ORM提供了AOP来处理这个问题

  db.Aop.OnExecutingChangeSql = (s, p) =>
            {
                foreach (var item in p)
                {
                    if (item.ParameterName.Contains("("))
                    {
                        var oldName = item.ParameterName;
                        //重点看这儿,把参数名变成正常的名字
                        item.ParameterName = item.ParameterName
                                    .Replace("(""_")
                                    .Replace(")""_")
                                    .Replace(".""_");
                        s = s.Replace(oldName, item.ParameterName);
                    };
                }
                return new KeyValuePair<string, SugarParameter[]>(s, p);
            };

 

12、与另一个进程被死锁在 锁 | 通信缓冲区 资源上,并且已被选作死锁牺牲品。请重新运行该事务。

(1) 出现这个错一般是超过数据库处理上限,可以用异步提升性能,max pool size字符串设置大些

(2) 并发不高情况一般是线程安全引起的, 看文档:偶发错误

13、The connection was not closed. The connection's current state is connecting

看文档:偶发错误

14、参数名有空格特殊符号

对性能会有影响,能局部修改配置就局部,尽量不要全局使用

//全局生效
SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
{
    ConnectionString = $"Data Source={dbFileName};",
    DbType = DbType.Sqlite,
    IsAutoCloseConnection = true,
    MoreSettings = new ConnMoreSettings
    {
        IsCorrectErrorSqlParameterName= true// 5.1.4.111及以上版本
    }
});
 
//局部生效
db.CurrentConnectionConfig.MoreSettings=new MoreSettings(){  IsCorrectErrorSqlParameterName= true}

15、Connect Timeout expired. All pooled connections are in use

并发不高出现这个错一般是线程安全问题

SqlSugar常见问题汇总的更多相关文章

  1. CentOS安装Oracle数据库详细介绍及常见问题汇总

    一.安装前准备 1.软件硬件要求 操作系统:CentOS 6.4(32bit)Oracle数据库版本:Oracle 10g(10201_database_linux32.zip)最小内存:1G(检查命 ...

  2. SVN集中式版本控制器的安装、使用与常见问题汇总

    SVN是Subversion的简称,是一个开放源代码的版本控制系统,它采用了分支管理系统,集中式版本控制器 官方网站:https://www.visualsvn.com/ 下载右边的服务器端,左边的客 ...

  3. H5项目常见问题汇总及解决方案

    H5项目常见问题汇总及解决方案 H5   2015-12-06 10:15:33 发布 您的评价:       4.5   收藏     4收藏 H5项目常见问题及注意事项 Meta基础知识: H5页 ...

  4. Installshield脚本拷贝文件常见问题汇总

    原文:Installshield脚本拷贝文件常见问题汇总 很多朋友经常来问:为什么我用CopyFile/XCopyFile函数拷贝文件无效?引起这种情况的原因有很多,今天略微总结了一下,欢迎各位朋友跟 ...

  5. MVC 网站部署常见问题汇总

    一:TGIShare项目是一个MVC5的网站程序,部署在了IIS上,使用的Windows验证方式,并在本机设置了计划任务定时调用某个地址执行命令.问题汇总如下: 1.Window Server 200 ...

  6. J2EE进阶(十)SSH框架整合常见问题汇总(一)

    SSH框架整合常见问题汇总(一) 前言 以下所列问题具有针对性,但是遇到同类型问题时均可按照此思路进行解决. HTTP Status 404 - No result defined for actio ...

  7. mysql进阶(十六)常见问题汇总

    mysql进阶(十六)常见问题汇总 MySQL视图学习: http://www.itokit.com/2011/0908/67848.html 执行删除操作时,出现如下错误提示: 出现以上问题的原因是 ...

  8. 转---CentOS安装Oracle数据库详细介绍及常见问题汇总

    一.安装前准备 1.软件硬件要求 操作系统:CentOS 6.4(32bit)Oracle数据库版本:Oracle 10g(10201_database_linux32.zip)最小内存:1G(检查命 ...

  9. (转)CloudStack 安装及使用过程中常见问题汇总

    CloudStack 安装及使用过程中常见问题汇总             在做工程项目中对CloudStack 安装及使用过程中常见的几个问题及如何解决做一个总结.   1.Windows XP虚拟 ...

  10. thymeleaf的常见问题汇总

    thymeleaf的常见问题汇总 1.thymeleaf th:href 多个参数传递格式 th:href="@{/Controller/update(param1=1,param2=${p ...

随机推荐

  1. 手把手教你在 Windows 环境中搭建 MQTT 服务器

    前言 前些天要对接一家硬件商的设备数据,对方使用的 MQTT 协议点对点透传,所以又赶紧搭建 MQTT 服务器,写 .NET 程序接收数据等等,今天分享一下如何搭建 MQTT 服务器. MQTT 协议 ...

  2. CentOS 7 qemu 创建虚拟机简单流程

    查看是否支持虚拟化 egrep -o '(vmx|svm)' /proc/cpuinfo 如果有显示则支持虚拟化,没有显示则不支持   安装qemu 和virt 系列软件包 yum install q ...

  3. Flink异步IO

    本文讲解 Flink 用于访问外部数据存储的异步 I/O API. 对于不熟悉异步或者事件驱动编程的用户,建议先储备一些关于 Future 和事件驱动编程的知识. 对于异步 I/O 操作的需求 在与外 ...

  4. ME51N 采购申请屏幕增强仅显示字段

    1.业务需求 通过委外工单生成的采购申请,需要将自定义"图号"字段显示在采购申请中,且只用于显示即可 2.增强实现 增强表EBAN的结构CI_EBANDB 增强点CMOD:MERE ...

  5. 反应式编程 RxJava 设计原理解析

    本文首发于 vivo互联网技术 微信公众号 链接: https://mp.weixin.qq.com/s/duO1pAfaKUI2_x_GVvZHMg作者:Yunjie Ma 一.ReactiveX ...

  6. 2021 VDC :vivo 互联网服务亿级用户的技术架构演进之路

    关注公众号[vivo互联网技术]--回复[2021VDC]获取大会PPT. 2021年12月16日,vivo 开发者大会圆满落幕.在互联网技术专场中,来自vivo 互联网技术的6位研发专家,从基础架构 ...

  7. 如果很好说出finalize用法,面试官会认为你很资深

    我在面试Java候选人的时候,有时候会通过finalize问及候选人在JVM方面的技能,一般的问法是:你知不知道finalize方法,在项目里有没有重写过这个方法?在本文里就将详细来说下这个知识点. ...

  8. git branch 分支命令图文详解

    https://blog.csdn.net/wangdawei_/article/details/124556712 git branch 分支命令详解git branch (查看本地分支)git b ...

  9. C#排序算法6:快速排序

    快速排序由C. A. R. Hoare在1960年提出.它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分 ...

  10. python连接liunx主机:paramiko类基本操作

    一.下载paramiko类 pip install paramiko 二.实现过程 # coding utf-8# author:Mr.white import paramiko # 创建SSHCli ...