3

在尝试使用 Ruby 连接到 SQLServer 数据库后,我终于发现了TinyTDS,它太棒了。

但是,它需要用户名和密码才能与数据库通信。在过去的 C# 测试中,我们使用 SSPI 来提供此功能,以便任何测试人员都可以获取脚本并运行它,并且它将使用他们的 Windows 身份验证详细信息。

我找不到使用 TDS 的方法(开始怀疑当前版本不可能)并希望有人可能证明我错了,或者有其他建议?

干杯。

4

1 回答 1

3

找到了解决方案。

我安装的 tiny-tds 是 0.51 版。

最新版本具有 SSPI,因此要做到这一点:

gem install tiny_tds --version ">= 0.6.0.rc1"

这无需指定用户名/密码并默认使用 SSPI。

举个例子:

require  'tiny_tds'

    sql = "SELECT name from sys.databases"
    client = TinyTds::Client.new(:dataserver => "myserver", :database => "mydatabase")
    result = client.execute(sql)
    results = result.each(:symbolize_keys => true, :as => :array, :cache_rows => true, :empty_sets => true) do |rowset| end
    #THIS IS TO OUTPUT IT TO THE CONSOLE
    for i in (0..result.fields.length)
      printf("%14s", result.fields[i])
    end
    for j in (0...result.affected_rows)
      puts ""
      for i in (0...result.fields.length)
        printf("%14s",results[j].at(i))
      end
    end

将打印出数据库名称列表,使用 SSPI 访问数据库。

于 2013-01-16T01:09:37.900 回答