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

标签 ruby-on-rails xml ruby database scripting

我正在开发一个需要发送短信的应用程序,因此我将运营商信息存储在数据库中。我还需要 XML 文件中的信息供客户端代码读取。为了做到这一点,我正在编写一个脚本,从数据库中读取运营商信息并在配置目录中创建一个 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没有定义,这是有道理的。我怎样才能让这个脚本访问数据库中的 Carrier 对象?

此外,如果有人知道如何轻松地将我从数据库中读取的内容转换为适当的 XML,那就太好了。我打算很快写一些定制的东西。

谢谢!

最佳答案

您可以通过像这样定义您的任务来启用 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) 的别名。

关于ruby-on-rails - 如何从 lib/tasks 中的任务访问我的 Rails 数据库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/717265/

相关文章:

ruby-on-rails - 具有不同名称的 Rails 委托(delegate)

javascript - 显示用户角色 : angularjs, rolify,rails 应用程序

ruby-on-rails - AWS Beanstalk cli-tool 配置验证异常

java - Spring RestClient 内容类型不匹配

协助创建 XSD 的 Java 库?

java - 使用通用测试数据扫描 Sonarqube 6.4 中 ruby​​ 文件的覆盖率数据

ruby-on-rails - 仅为本地主机创建 rails 路由

ruby-on-rails - 如何通过接受嵌套属性的关联为多对多创建新记录?

ruby-on-rails - 使用 Arel 表达 CTE

c# - 在 C# 中从 Web 检索匿名类型