在尝试使用 Ruby 连接到 SQLServer 数据库后,我终于发现了TinyTDS,它太棒了。
但是,它需要用户名和密码才能与数据库通信。在过去的 C# 测试中,我们使用 SSPI 来提供此功能,以便任何测试人员都可以获取脚本并运行它,并且它将使用他们的 Windows 身份验证详细信息。
我找不到使用 TDS 的方法(开始怀疑当前版本不可能)并希望有人可能证明我错了,或者有其他建议?
干杯。
在尝试使用 Ruby 连接到 SQLServer 数据库后,我终于发现了TinyTDS,它太棒了。
但是,它需要用户名和密码才能与数据库通信。在过去的 C# 测试中,我们使用 SSPI 来提供此功能,以便任何测试人员都可以获取脚本并运行它,并且它将使用他们的 Windows 身份验证详细信息。
我找不到使用 TDS 的方法(开始怀疑当前版本不可能)并希望有人可能证明我错了,或者有其他建议?
干杯。
找到了解决方案。
我安装的 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 访问数据库。