- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 vb.net (visual studio 2010) 中创建了可执行应用程序。总的来说,我正在尝试将我所有的 MSSQL 数据移动到 MySQL。
环境:MS Server 2003 R2 上的应用程序 - x64 SP2MS Server 2008 R2 标准 x64 SP1 上的 MSSQLUbunto 上的 MySql使用:2.0 的连接器/网络
现在,如果我只执行 1000 次,它工作正常,从 sql server 循环读取 1000 次,并且为每条记录调用 inserttable 函数并插入记录。当我尝试 5000 条记录时,问题就来了。在记录 2932(以及之后的所有条目),插入产生以下内容:错误:
MySql.Data.MySqlClient.MySqlException: Unable to connect to any of the specified MySQL hosts. ---> System.Net.Sockets.SocketException: Only one usage of each socket address (protocol/network address/port) is normally permitted 192.168.0.14:3306
at System.Net.Sockets.Socket.EndConnect(IAsyncResult asyncResult)
at MySql.Data.Common.StreamCreator.CreateSocketStream(IPAddress ip, Boolean unix)
at MySql.Data.Common.StreamCreator.GetStreamFromHost(String pipeName, String hostName, UInt32 timeout)
at MySql.Data.Common.StreamCreator.GetStream(UInt32 timeout)
at MySql.Data.MySqlClient.NativeDriver.Open()
--- End of inner exception stack trace ---
at MySql.Data.MySqlClient.NativeDriver.Open()
at MySql.Data.MySqlClient.Driver.Open()
at MySql.Data.MySqlClient.Driver.Create(MySqlConnectionStringBuilder settings)
at MySql.Data.MySqlClient.MySqlConnection.Open()
知道为什么在 2900 个条目之后会发生这种情况吗?
连接字符串
<add name="MSSQLdb" connectionString="Data Source=192.168.0.13; Initial Catalog=sqlserverdb; User ID = IUSR_sqlserverusername; Password=sqlserverpwd"/>
<add name="MySQLdb" connectionString="server=192.168.0.14;Port=3306;Uid=dbusername; Pwd=dbpassword;database=dbname; pooling=false" providerName="MySql.Data.MySqlClient" />
主要功能
Dim myCon As SqlConnection = New SqlConnection(MSSQLDBConn)
Dim sSQL As String = 'SELECT TOP 5000 * FROM mssqlservertable'
Dim myCmd As SqlCommand = New SqlCommand(sSQL, myCon)
Dim iRetVal As Integer = 0
Try
If myCon.State <> Data.ConnectionState.Open Then
myCon.Open()
End If
Dim drOrder As SqlDataReader = myCmd.ExecuteReader()
If drOrder.HasRows Then
Dim sOutput As String = ""
Do While drOrder.Read()
Dim sRetVal As String = ""
sRetVal = InsertTable(drOrder("ID"), _
drOrder("ID2"), _
drOrder("Resume"), _
drOrder("DateCreated"), _
drOrder("DateModified"))
If sRetVal.StartsWith("ERROR") = True Then
LogIt("ID: " & drOrder("ID") & " iCnt: " & iCnt & " Error: " & sRetVal)
ToolStripStatusLabel1.Text = "Error found."
End If
iCnt += 1
If iCnt Mod 100000 = 0 Then
ToolStripStatusLabel1.Text = "Current count: " & iCnt
Application.DoEvents()
End If
Loop
ToolStripStatusLabel1.Text = "Final count: " & iCnt
Else
ToolStripStatusLabel1.Text = "No rows"
End If
Catch sqlEx As MySqlException
MessageBox.Show("Sql error: " & sqlEx.ToString)
Catch ex As Exception
MessageBox.Show("Regular error: " & ex.ToString)
Finally
myCon.Close()
myCon.Dispose()
End Try
Catch ex As Exception
MessageBox.Show("Error: " & ex.ToString)
End Try
插入函数
Function InsertTable(ByVal ID As Integer, ByVal ID2 As Integer, _
ByVal Resume As String, ByVal DateCreated As DateTime, _
ByVal DateModified As DateTime) As String
Dim sRetVal As String = ""
Dim myCon As MySqlConnection = New MySqlConnection(MySQLDBConn)
Dim sSQL As String = "INSERT INTO mysqltable (ID, ID2, Resume,DateCreated, DateModified)" _
& " VALUES (?ID, ?ID2, ?Resume, ?DateCreated, ?DateModified);"
Dim myCmd As MySqlCommand = New MySqlCommand(sSQL, myCon)
myCmd.CommandType = Data.CommandType.Text
myCmd.Parameters.Add(New MySqlParameter("?ID", MySqlDbType.Int32)).Value = ID
myCmd.Parameters.Add(New MySqlParameter("?ID2", MySqlDbType.Int32)).Value = ID2
myCmd.Parameters.Add(New MySqlParameter("?Resume", MySqlDbType.LongText)).Value = Resume
myCmd.Parameters.Add(New MySqlParameter("?DateCreated", MySqlDbType.DateTime)).Value = DateCreated
myCmd.Parameters.Add(New MySqlParameter("?DateModified", MySqlDbType.DateTime)).Value = DateModified
Try
If myCon.State <> Data.ConnectionState.Open Then
myCon.Open()
End If
myCmd.ExecuteNonQuery()
myCmd.Dispose()
Catch sqlEx As MySqlException
sRetVal = "ERROR: Sql error: " & sqlEx.ToString
Catch ex As Exception
sRetVal = "ERROR: Regular error: " & ex.ToString
Finally
myCon.Close()
myCon.Dispose()
End Try
Return sRetVal
End Function
最佳答案
我想您正在用尽所有可用的临时 TCP/IP 端口,因为快速连续地打开/关闭数据库连接。您应该打开一次连接并为每个插入使用该连接。史蒂夫关于使用池的建议也应该为您解决这个问题,因为连接将以类似的方式透明地共享。
关于2931 插入后 MySql 错误 "Unable to connect to any of the specified MySQL hosts.",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14751980/
在 CSS 中,我从来没有真正理解为什么会发生这种情况,但每当我为某物分配 margin-top:50% 时,该元素就会被推到页面底部,几乎完全消失这一页。我假设 50% 时,该元素将位于页面的中间位
我想在 MongoDB 中使用 Grails2.5 中的“ElasticSearch”插件。我的“BuildConfig.groovy”文件是: grails.servlet.version = "3
我有一个我想要处理的 OHLC 股票报价数组。 Open High Low Close Volume 2003-01-05
我尝试创建一个PreparedStatement: stmt = conn.prepareStatement("SELECT POLBRP, POLTYP, POLNOP, INCPTP, TRMTH
我的目录结构如下: root libA CMakeLists.txt ClassA.cpp libB CMakeLists.txt ClassB.cpp s
我是 DBMS 的新手。我在每个用户的不同 csv 文件中都有车辆痕迹。格式:名称,时间戳,纬度,经度,randomId。例如:user0,2008-10-2309:42:25,441972.6942
我需要为我的应用程序打上烙印,并且只需要自定义少量图像,代码库是相同的,只是生成的常量很少。 由于aapt 允许指定许多资源目录,有没有办法在Eclipse .classpath 文件中指定res 目
我希望在我的应用程序中实现 JWT,因为我正在通过引用以下内容对其进行一些研发:https://stormpath.com/blog/jwt-java-create-verify .当我尝试通过提取声
我正在尝试通过设置限制获取数据并根据时间戳对数据进行排序,但在运行应用程序时崩溃并显示此错误消息: 查询无效。在指定顺序之前不得指定起点。 我不知道为什么会这样。如何解决? 我需要数据序列和排序。
我正在使用Elasticsearch和Tire进行Rails3项目。当我尝试运行Elastic-search时,安装它后,出现以下错误: The stack size specified is too
我创建了一个简单的函数来执行 Http PUT 请求 - public string checkIfUserExists(string userName) { var endP
Java 安全管理器允许通过定义如下子句来指定某些代码段的权限: ... grant codebase http://foo.bar.com/test.jar { permission java
这更像是一种验证。 在 Oracle/Java 教程页面上,例如 this , 我一直看到catch 旁边的“specify”就好像它是另一个语句在异常处理中具有一些功能。 据我所知,“catch o
本文整理了Java中org.batfish.specifier.ZoneNameRegexInterfaceSpecifier类的一些代码示例,展示了ZoneNameRegexInterfaceSpe
我正在尝试运行以下命令: ionic cordova run android --device 但我收到以下错误 BUILD FAILED in 3s (node:3956) Unha
在不包含 viewport 元标记的网页上,大多数移动浏览器会将页面上的部分或全部字体“提升”到大于 css 指定的大小。例如,在移动版 Safari 上,7px 的指定大小将提升为类似 12px 的
嗨,我不了解 keras fit_generator 文档。 我希望我的困惑是理性的。 有一个batch_size还有分批训练的概念。使用 model_fit() ,我指定一个 batch_size
我使用 IProviderSearchContext 在 Sitecore 8.1(Lucene 搜索)中搜索特定项目,并获得每个项目的两个版本(en、ar)。我的问题是:我是否必须为每个查询指定:
Except in a declaration of a constructor, destructor, or conversion function, at least one defining-
使用 GooglePageSpeed 分析在线商店(Shopware)导致每个图像上出现许多“未指定到期时间”的线条。 我想知道是因为网络服务器 (nginx) 在所有图像的响应中添加了 Last-M
我是一名优秀的程序员,十分优秀!