4

我想查询我的数据库并获取结果并将它们导出到 .txt、.cvs 或 .xls

mysql 数据库未托管在我的本地计算机上

这是我访问数据库并在屏幕上返回结果的代码:

 #!/usr/bin/ruby
 require 'mysql'
 require 'watir'
 require "win32ole"

 excel = WIN32OLE::new('excel.Application')
 workbook = excel.Workbooks.Add
 worksheet = workbook.Worksheets(1)

 mysql = Mysql.init()
 mysql.connect(host='hostname', user='username', passwd='pwd', db='DBname')

 results = mysql.query("Select * FROM table") 
 results.each{|row|; puts row;}
 mysql.close()

 worksheet.SaveAs("C:\\Scripts\\DB_Test\\Test.xlsx") 
 workbook.Close
4

2 回答 2

6

.csv 很简单。我不确定您从 mysql.query 得到什么,但请确保每一行都是一个数组,其中包含您想要放入 csv 行的内容,然后执行以下操作:

require 'csv'

CSV.generate do |csv|
  csv << ["headers","describing","the data"]
  mysql.query("SELECT * FROM table").each { |row| csv << row }
end

csv 支持在标准库中,因此不需要任何 gem。请注意,标准库在 1.8 和 1.9 之间发生了变化 - 该示例应适用于 1.9。

于 2012-02-23T21:30:07.250 回答
2

这颗宝石可能对你有很大帮助。您可以使用漂亮而灵活的 DSL 导出任何复杂的查询。

https://github.com/stevenbarragan/julia_builder

于 2015-10-29T10:57:12.790 回答