- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这个问题:我正在编写一些 Python 脚本,而直到现在,在整个脚本中使用单个 MySQLConnector 连接(仅在脚本末尾关闭它)我完全没有问题,最近我遇到了一些问题。
如果我在脚本开头创建一个连接,类似于(忽略安全问题,我知道):
db_conn = mysql.connector.connect(user='root', password='myPassword', host='127.0.0.1', database='my_db', autocommit=True)
然后总是像这样使用它:
db_conn.cursor(buffered=True).execute(...)
或者 fetch 和其他方法,我会得到如下错误:
Failed executing the SQL query: MySQL Connection not available.
或
Failed executing the SQL query: No result set to fetch from.
或
OperationalError: (2013, 'Lost connection to MySQL server during query')
代码是正确的,只是不明白为什么会这样。也许是因为我在异步中多次并发运行相同的函数(尝试了 2 次),所以可能是对游标的并发访问导致了这个?
我发现有人每次都使用不同的数据库连接来修复它 ( here )。
我尝试为对数据库的每个查询创建一个新连接,现在完全没有错误。它工作正常,但似乎有点矫枉过正。想象一下调用 async 函数 10 次或 100 次……会创建大量的数据库连接。会不会出问题?它会耗尽内存吗?而且,我想它会放慢速度。
有没有办法通过对所有查询保持相同的连接来解决这个问题?为什么会这样?
最佳答案
MySQL 是一个有状态的协议(protocol)(在这方面更像 ftp 而不是 http)。这意味着如果您正在运行多个异步线程,这些线程在同一个 MySQL 连接上发送和接收数据包,则该协议(protocol)无法处理。服务器和客户端会感到困惑,因为消息会以错误的顺序到达。
我的意思是,如果不同的异步例程同时尝试使用数据库连接,您很容易陷入麻烦:
async1: sends query "select * from table1"
async2: sends query "insert into table2 ..."
async1: expects to fetch rows of result set, but receives only rows-affected and last insertid
从那里开始变得更糟,例如,当存在一个结果集尚未关闭其结果集的现有查询时,无法执行查询。或者更糟糕的是,您可以准备两个具有参数的查询,然后随后为错误 查询发送参数。
您可以对多个查询使用相同的数据库连接,但不要在并发执行的异步线程之间共享相同的连接。为了安全起见,每个异步例程都应该打开自己的连接。然后打开给定连接的线程可以使用该连接进行多个查询。
可以把它想象成一个调用中心,其中有几十个人,每个人都有自己的电话线。他们当然不应该尝试共用一条电话线并进行多次通话!唯一可行的方法是,如果电话中说出的每个词都带有一些识别信息,说明它属于哪个 session 。 “您好,我是史密斯先生,就第 1234 号病例来电,您刚才问我的问题的答案是……”
但是 MySQL 的协议(protocol)不会那样做。它假定每条消息都是前一条消息的延续,并且客户端和服务器都记得那是什么。
关于python - MySQLConnector (Python) : New DB connection for each query vs. 单个连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65169638/
我使用 Visual Studio 2012。我有控制台应用程序。我应该连接到mysql服务器,我使用mysql连接器/C++,但是当我从表中读取时,例如,如果我应该得到“word”,我会得到四个未知
这是我的问题,我正在尝试将 Java 程序连接到 MySQL 数据库。我这里没有使用IDE。发生的情况是,当我将 mysql-connector-java-bin.jar 添加为 CLASSPATH
我在 C# 中有一个 foreach 循环,它执行 MySql 命令来检查结果是否存在,问题是我不知道如何更新与 @id_line 对应的参数中的值,错误是在第二次迭代时抛出 foreach (Str
前言:我对 C# 的 MySqlConnector 和一般的 MySql 还很陌生。 我想实现的目标是执行一个查询,然后通过FOUND_ROWS获取SqlDataReader中返回的记录数。 这是我正
我正在使用 MySQLConnector 和 C# 连接到我的数据库。一切运行正常,但是当我在另一台机器上尝试我的程序时,我收到“无法加载文件或程序集'MySql.Data”错误。我刚刚将 .exe
我正在尝试将时间从 UTC 格式的 Unix 时间戳插入到 MySQL 表中。使用from_unixtime(timestamp)可以进行解析,但它使用的时区是“当前时区”,这显然是连接的当前时区,而
我正在开发一个连接到 MySQL 数据库的 C#.NET 应用程序,并使用一些不安全的代码来使用旧的 C++ dll。 程序一启动,就会加载dll并分配一个指针,然后初始化一些C#变量,然后删除指针。
需要帮助解决一些愚蠢的密码问题。以下问题: 不能用一些密码连接到mysql服务器^^ 如果我使用具有相同“连接字符串”详细信息的密码,例如: 以下密码完全在MySql Server中(引号、双引号、分
我从 MySqlCommand.ExecuteNonQuery() 得到这个异常: Index and length must refer to a location within the strin
我正在使用: MySqlCommand comHash = new MySqlCommand("MY_FUNCTION", con); comHash.CommandType = CommandTyp
我需要别人的帮助。 我遵循教程 Streaming Data from MySQL into Kafka with Kafka Connect and Debezium但我无法使用 Debezium
我有以下代码: 导入 MySql.Data.MySqlClient导入 MySql.Data.Types 公开课FormMain 私有(private)子表单Main_Load ... ' Ope
我正在编写单元测试(技术上是集成测试,因为我正在连接到数据库)并且我想在测试中的事务中创建记录,并在测试完成后回滚所有数据库修改。我的想法是,我将通过一个 API 调用创建另一个 API 调用期望在数
我在 MySql 中有一个存储过程,它插入 10.000 个寄存器。当我从 MySql 命令行执行它时,查询需要 1 秒,但是当我从我编写的 .NET C# 应用程序执行它时,它需要大约 8 秒。 你
SELECT CONVERT(LAST_INSERT_ID(), SIGNED INTEGER); MySqlCommand.ExecuteScalar() 和 MySqlDataReader.Get
我正在使用 Unity 2018 开发 WebGL 应用。 我需要访问托管在同一台服务器上的 MySQL 数据库。 我的问题是:我可以使用 C# 和 MySqlConnector(我更喜欢的解决方案)
我正在尝试使用 C# 中的 MySqlCommand 对象(使用 MySQL 连接器库)在一个查询中将多条记录插入到一个表中。 我知道如何做到这一点的唯一方法是自己动态构建查询并设置 comman
我有这个问题:我正在编写一些 Python 脚本,而直到现在,在整个脚本中使用单个 MySQLConnector 连接(仅在脚本末尾关闭它)我完全没有问题,最近我遇到了一些问题。 如果我在脚本开头创建
我有这个问题:我正在编写一些 Python 脚本,而直到现在,在整个脚本中使用单个 MySQLConnector 连接(仅在脚本末尾关闭它)我完全没有问题,最近我遇到了一些问题。 如果我在脚本开头创建
我正在使用 pandas 和 sqlalchemy,并且希望将 DataFrame 加载到 MySQL 数据库中。我目前正在使用此代码片段: db_connection = sqlalchemy.cr
我是一名优秀的程序员,十分优秀!