加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 22:45:14 所属栏目:百科 来源:网络整理
导读:我正在开发一个需要发送短信的应用程序,因此我将操作符信息存储在数据库中.我还需要 XML文件中的信息来读取客户端代码.为了实现这一点,我正在编写一个脚本,从DB读取操作符信息并在config目录中创建XML文件.我觉得这个脚本最适合lib / tasks. 我需要从这个脚
我正在开发一个需要发送短信的应用程序,因此我将操作符信息存储在数据库中.我还需要 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

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

rake RAILS_ENV=development my_task
rake RAILS_ENV=production my_task

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

Carrier.all.to_xml

请注意,方法.all是Rails的最新成员,并且是.find(:all)的别名.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读