热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

解决VS写C#项目导入MySQL数据源报错“Youhaveausableconnectionalready”问题的正确方法

本文介绍了在VS写C#项目导入MySQL数据源时出现报错“Youhaveausableconnectionalready”的问题,并给出了正确的解决方法。详细描述了问题的出现情况和报错信息,并提供了解决该问题的步骤和注意事项。

关于这个问题,国内外网站讨论的不是很多,可能出现这个问题的不是很多吧。

关键是:解决方法没讲清楚,或不正确。所以我这里就根据经验讲讲,到底该如何处理这个问题才正确。



一、问题描述


You have a usable connection already
图1 为项目添加Mysql数据源报错

 如图:当给项目添加数据集的时候,一步一步操作到 选择所需的[表],然后点击[完成]就会来个报错:"某些更新命令未能自动生成,数据库返回以下错误:You have a usable connection already";(如果你是英文版的VS,弹出的信息是:"Some updating commands could not be generated automatically. The database returned the following error: You have a usable connection already")

这个时候你点击[确认],它就会弹出另一个错误信息:


error
图2 错误信息

 

如图,错误信息继承上一条错误,内容是:"处理数据库对象时发生了一个或多个错误。请单击“确定”以继续进行,或单击“取消”以返回向导并尝试修复错误:未能检索表或视图‘xxx’的架构信息"。(如果你是英文版的VS,那么错误信息为:“[Data Source Configuration Wizard] Could not retrieve schema information for table or view 'xxx' ”)


二、问题确认


  1. 首先:这个Mysql的一个BUG![参阅这个BUG]
  2. 这个问题国内外的网络平台上一直都有人问,从VS 2012 到 如今的 VS 2019,而且,Mysql connector net从6.6.8到如今的8.0.17前前后后发布了近30个版本,难道一直没有解决这个Bug???
  3. 国内的解决方法基本一致,因为“CV大法”盛行,但看来看去,方法来源基本都是这篇博客[康先森·博客园·vs studio 2017/2015 连接mysql报错 You have a usable connection already](未能悉数了解,大致是这样)
  4. 国外的处理方法差不多的也有[You have a usable connection already]  [Visual Studio 2015添加数据源错误]
  5. 但是,就像我第3点说的那样,难道现在都发布8.0.17版本了,我们因为出现这个问题就只能退回去用低版本的6.9.9吗?难道Mysql更新了二三十个版本,这个问题还是没有解决吗?显然这里有文章。

三、问题解决


(1) 现行方法测试

首先我尝试过他们说的那些方案:使用MySQL connector net 6.9.9 和 MySQL for visual studio 2.0.4。但是,并没有什么用,添加数据源一样出问题。你们也可以尝试一下,我把官方的旧版本链接放出来,想捣腾捣腾的,大可以玩一玩:


  • Mysql connector net 存档版本
  • Mysql for visual studio 存档版本
  • Mysql 各种产品的存档版本



(2) 不想捣腾的,可以直接看我提供的解决方案:


图3 删除这两个产品

 


  1. 查看你电脑中的两个产品的版本,并记下来;
  2. 关闭所有VS窗口,删除你电脑中的两个产品:MySQL for visual studio 和 MySQL Connector Net;
  3. 下载这两个产品:如果是旧版本,就用上面给的链接;如果是新版本,就用下面给的链接;
  4. 重要!!必须!一定!先安装MySQL for visual studio;
  5. 重要!!必须!一定!后安装MySQL Connector Net;
  6. 重启VS;
  7. 重新导入数据集,这时候就不会报错了;

   [MySQL for visual studio官网最新版]

   [MySQL Connector Net官网最新版]


(3) 重新安装产品后的状态


图4 重装产品后的状态

 此时如果你查看电脑安装的软件,点击[安装时间]来排序的话,MySQL for visual studio 在 MySQL Connector Net 底下;

当然如果你严格按照第 (2) 小节的步骤4,5操作,肯定是没问题的:


图5 正常的数据集添加结果

 

如图:从[一、问题描述]中点击[完成]后的结果应该能在右侧显示所选[表]的架构信息,即表的各个字段信息,这也是图2 报错信息提示里应该有的信息。至此,这个问题就解决了。


参考文档

https://bugs.mysql.com/bug.php?id=83754

https://www.cnblogs.com/KangYh/p/10996901.html

https://stackoverflow.com/questions/54785813/you-have-a-usable-connection-already

https://stackoverflow.com/questions/38862525/mysql-visual-studio-2015-you-have-a-usable-connection-already?rq=1

https://stackoverflow.com/questions/54798166/mysql-visual-studio-2017-error-you-have-a-usable-connection-already


 


个人经验,有不当之处还请指正。

但是截止发文日期,国内网站还没有提出这么解决的。

解决方法不一定适用所有人。



推荐阅读
  • 本文介绍了adg架构设置在企业数据治理中的应用。随着信息技术的发展,企业IT系统的快速发展使得数据成为企业业务增长的新动力,但同时也带来了数据冗余、数据难发现、效率低下、资源消耗等问题。本文讨论了企业面临的几类尖锐问题,并提出了解决方案,包括确保库表结构与系统测试版本一致、避免数据冗余、快速定位问题等。此外,本文还探讨了adg架构在大版本升级、上云服务和微服务治理方面的应用。通过本文的介绍,读者可以了解到adg架构设置的重要性及其在企业数据治理中的应用。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了PhysioNet网站提供的生理信号处理工具箱WFDB Toolbox for Matlab的安装和使用方法。通过下载并添加到Matlab路径中或直接在Matlab中输入相关内容,即可完成安装。该工具箱提供了一系列函数,可以方便地处理生理信号数据。详细的安装和使用方法可以参考本文内容。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • flowable工作流 流程变量_信也科技工作流平台的技术实践
    1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • MongoDB用户验证auth的权限设置及角色说明
    本文介绍了MongoDB用户验证auth的权限设置,包括readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase、cluster相关的权限以及root权限等角色的说明和使用方法。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • Postgresql备份和恢复的方法及命令行操作步骤
    本文介绍了使用Postgresql进行备份和恢复的方法及命令行操作步骤。通过使用pg_dump命令进行备份,pg_restore命令进行恢复,并设置-h localhost选项,可以完成数据的备份和恢复操作。此外,本文还提供了参考链接以获取更多详细信息。 ... [详细]
  • 本文介绍了Python语言程序设计中文件和数据格式化的操作,包括使用np.savetext保存文本文件,对文本文件和二进制文件进行统一的操作步骤,以及使用Numpy模块进行数据可视化编程的指南。同时还提供了一些关于Python的测试题。 ... [详细]
  • Unity3D引擎的体系结构和功能详解
    本文详细介绍了Unity3D引擎的体系结构和功能。Unity3D是一个屡获殊荣的工具,用于创建交互式3D应用程序。它由游戏引擎和编辑器组成,支持C#、Boo和JavaScript脚本编程。该引擎涵盖了声音、图形、物理和网络功能等主题。Unity编辑器具有多语言脚本编辑器和预制装配系统等特点。本文还介绍了Unity的许可证情况。Unity基本功能有限的免费,适用于PC、MAC和Web开发。其他平台或完整的功能集需要购买许可证。 ... [详细]
  • 作者表示自己最近工作非常忙碌,无法抽出时间写作。他计划在未来的几天内写关于namespace与C#的名字解析以及数据库内容转化为excel文件下载的知识。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • 本文介绍了一种轻巧方便的工具——集算器,通过使用集算器可以将文本日志变成结构化数据,然后可以使用SQL式查询。集算器利用集算语言的优点,将日志内容结构化为数据表结构,SPL支持直接对结构化的文件进行SQL查询,不再需要安装配置第三方数据库软件。本文还详细介绍了具体的实施过程。 ... [详细]
author-avatar
三封封封_391
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有