使用go-mssqldb查询SQL Server的golang方法

3
我正在尝试使用go查询SQL Server 2008 R2。https://github.com/denisenkom/go-mssqldb。 SQL Server 2008 R2实例位于Windows Server 2008 R2的VM上;我在Win 7 VMWare主机下进行开发,并从那里运行程序以查询VM上的数据库。该数据库已经启动并运行在服务器VM上的应用程序。以下是代码。
我得到的错误是:
[编辑2017-03-14:指定端口时出现新错误]
登录错误:read tcp 192.168.91.1:15222->192.168.91.135:1433: wsarecv:远程主机强制关闭了一个现有的连接。
当指定SQL Server端口(1433)时返回此错误。包括或不包括实例都不会改变它。
SQL Server已配置为允许远程连接,启用了SQL Server身份验证,连接未加密,启用了TCP/IP,IPALL端口=1433。防火墙已开放TCP 80、443、1433、1434;UDP 1433、1434。在将数据库实例添加到连接字符串之前,我遇到了不同的错误。
SQL服务器日志似乎表明机器正在通信。IP地址是VMWare主机和虚拟机的地址。SQL Server浏览器服务正在运行(帐户为“本地服务”)。SQL Server代理程序未运行。我尝试使用ODBC和ADO连接字符串,但似乎出现了相同的错误。任何帮助将不胜感激。
package main
import (
   // Import go-mssqldb strictly for side-effects
   _ "github.com/denisenkom/go-mssqldb"
   "database/sql"
   "log"
)

func main() {
   var n_tables int

   println (sql.Drivers())

   // URL connection string formats
   //    sqlserver://sa:mypass@localhost?database=master&connection+timeout=30         // username=sa, password=mypass.
   //    sqlserver://sa:my%7Bpass@somehost?connection+timeout=30                       // password is "my{pass"
   // note: pwd is "myP@55w0rd"
   connectString := "sqlserver://SBM:myP%4055w0rd@VM17:1433?database=AE&connection+timeout=30"
   println("Connection string=" , connectString )

   println("open connection")
   db, err := sql.Open("mssql", connectString)
   defer db.Close()
   println ("Open Error:" , err)
   if err != nil {
      log.Fatal(err)
   }

   println("count records in TS_TABLES & scan")
   err = db.QueryRow("Select count(*) from ts_tables").Scan(&n_tables)
   if err != nil {
      log.Fatal(err)
   }
   println ("count of tables" , n_tables)

   println("closing connection")
   db.Close()
}

输出:

[2/2]0xc042002c20
Connection string= sqlserver://VM17_SBM:P%4055word@VM17:1433?database=VM17_SBM_AE_OE_REPO_CL&connection+timeout=30
open connection
Open Error: (0x0,0x0)
count records in TS_TABLES & scan
2017/03/14 19:48:01 Login error: read tcp 192.168.91.1:15222->192.168.91.135:1433: wsarecv: An existing connection was forcibly closed by the remote host.
exit status 1
2个回答

1

我在Github库作者的评论中找到了答案。

将"encrypt=disable"添加到连接字符串中即可解决。我正在下载建议的SQL Server 2008 R2 x64 SP3更新此处,并在有时间时安装它。但就目前而言,查询已经可以工作了。


0

GitHub存储库中写道:

确保SQL Server Browser Windows服务正在运行,并且没有防火墙阻止UDP端口1434。该驱动程序使用此服务获取SQL Server实例的TCP端口。

请确保您的SQLBrowser服务在主机上运行。

另外,您可以指定连接字符串和端口号(如果您的端口是静态的,则可以避免启动SQLBrowser服务的需要)。


我编辑了帖子并添加了额外的服务器配置信息。SQL浏览器正在运行。指定端口似乎没有关系。我不知道为什么NMAP说1434被过滤了:PORT STATE SERVICE VERSION 1433/tcp open ms-sql-s Microsoft SQL Server 2008 R2 10.50.1600; RTM 1434/tcp filtered ms-sql-m - mnemotronic
read udp 192.168.91.1:49155->192.168.91.135:1434 why the connection is udp - TheGameiswar
你启用了TCP吗?你能从外部ping通服务器吗? - TheGameiswar
TCP和UDP在两个端口上都已启用。我的系统上无法使用npcap,因此我无法进行nmap UDP扫描。我不允许从我的笔记本电脑“外部”访问虚拟机。 - mnemotronic

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接