如何从lib / tasks中的任务访问我的rails数据库?

时间:2009-04-04 15:30:39

标签: ruby-on-rails xml ruby database scripting

我正在开发一个需要发送短信的应用,因此我将运营商信息存储在数据库中。我还需要XML文件中的信息来读取客户端代码。为了实现这一点,我正在编写一个脚本,从DB读取运营商信息并在config目录中创建XML文件。我觉得这个脚本最适合lib / tasks。

我需要从这个脚本访问数据库,但我想使用一些对象来访问它。如果我使用

db = Mysql.new("domain", "username", "password", "database")

我必须为不同的环境保留多个版本,因为我不会一直使用MySQL。那将是非常草率的。我相信有办法做到这一点。我试图访问该对象......这是我到目前为止所做的:

RAILS_HOME = File.expand_path(File.join(File.dirname(__FILE__),"../.."))
RAILS_CONFIG = "#{RAILS_HOME}/config"

f = File.new("#{RAILS_CONFIG}/mls_widget_config.xml", "w")
carriers = Carrier.find_all
f.write carriers
f.close

但是Carrier没有定义,这是有道理的。如何让这个脚本访问DB中的Carrier对象?

另外作为一方,如果有人知道如何轻松地将我从数据库中读取的内容转换为适当的XML,那将是很棒的。我打算快速写一些自定义的东西。

谢谢!

3 个答案:

答案 0 :(得分:8)

您可以通过定义以下任务来启用Rake任务来访问您的模型:

task :my_task => :environment do
  # Task code
end

请注意授予此访问权限的=> :environment。然后,您可以指示您的Rake任务以这种方式使用不同的环境:

rake RAILS_ENV=development my_task
rake RAILS_ENV=production my_task

对于XML序列化,您可以使用内置的to_xml方法,例如:

Carrier.all.to_xml

请注意,方法.all是Rails的新增功能,并且是.find(:all)的别名。

答案 1 :(得分:2)

你实际上几乎就在那里;我只是建议将Rails环境作为脚本的一部分,如下所示:

RAILS_HOME = File.expand_path(File.join(File.dirname(__FILE__),"../.."))
RAILS_CONFIG = "#{RAILS_HOME}/config"
require "#{RAILS_CONFIG}/environment"

现在您应该可以访问所有域结构。 Rails还包括通过使用to_xml方法调用的默认XML序列化;试试Carrier.find(:all).to_xml

答案 2 :(得分:2)

按照惯例,lib / tasks通常保留用于rake任务 - 您可能希望将库代码放在自己的目录中。 lib / messaging,也许?

您是否正在运行旧版本的Rails? find_all在最近的版本中不起作用:'find(:all)'或者只是'all'是现在的方法。

File.new("#{RAILS_ROOT}/mls_widget_config.xml", "w") do |f|
  Carrier.all.each { |carrier| f.puts carrier.to_xml }
end