首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >go-mssqldb的golang SQL Server查询

go-mssqldb的golang SQL Server查询
EN

Stack Overflow用户
提问于 2017-03-13 06:06:52
回答 2查看 8.8K关注 0票数 3

我试图使用go查询SQL Server 2008 R2

https://github.com/denisenkom/go-mssqldb

Server 2008 R2实例位于Windows 2008 R2下的VM上;我正在Win 7 VMWare主机下进行开发,并在那里运行程序以查询VM上的DB。DB已经启动并运行了服务器VM上的一个应用程序。密码在下面。

我得到的错误是:

编辑2017-03-14 :当我指定端口时出现新错误

登录错误:读取TCP192.168.91.1:15222->192.168.91.135:1433: wsarecv:现有连接被远程主机强制关闭。

当指定Server端口(1433)时,将返回此错误。包括或不包括实例不会改变它。

Server配置为允许远程连接、Server、未加密连接、启用TCP/IP、IPALL port=1433。防火墙是开放的TCP在80,443,1433,1434;UDP在1433,1434。在将db实例添加到连接字符串之前,我得到了一个不同的错误。

server日志似乎是,以指示机器正在进行操作。IP地址用于VMWare主机和VM。 Server浏览器服务正在运行 (acct "Local“)。Server代理正在运行而不是。我尝试过使用ODBC和ADO连接字符串,并且似乎得到了相同的错误。任何帮助都将不胜感激。

代码语言:javascript
运行
复制
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()
}

产出:

代码语言:javascript
运行
复制
[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
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-03-15 04:12:37

我在图书馆作者对吉特卜的评论中找到了答案。

将"encrypt=disable“添加到连接字符串完成了这一任务。我正在下载Server 2008 R2 x64 正如这里所建议的的R2更新,并将在有时间时安装它。至于现在,虽然查询工作。

票数 1
EN

Stack Overflow用户

发布于 2017-03-13 09:37:38

github回购公司如下

确保Server浏览器窗口服务正在运行,并且没有防火墙阻塞UDP端口1434。驱动程序使用此服务获取Server实例的TCP端口

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

您还可以指定连接字符串和端口号(如果端口是静态的,这就否定了启动SQLBrowser服务的需要)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42757477

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档