我正在开发一个需要发送短信的应用程序,因此我将运营商信息存储在数据库中.我还需要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,那将是非常好的.我打算快速写一些自定义的东西.
谢谢!
您可以通过定义以下任务来启用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)
.