我最近重构了我的DataMapper代码,慢慢推出它,并让它在一个数据库上工作,但现在我在将它推出到我的费用数据库时遇到了问题。无法在任何地方找到答案,而且我已经尝试了很多摆弄。
我有一个表单(使用Sinatra)需要几个输入,前面加上"费用_",它应该获取该数据,将其发送到数据库,并将收据图像上传到S3。但是如果我打开DataMapper错误报告,我会得到一个nil的id和一个LocalJumpError。
这是我的代码:
数据库更新方法:
def dm_update(method_list,model,params,param_prefix,use_last_entry_if_param_empty=true)
model_data = model.new
method_list.each do |meth|
# e.g. param is :expense_date, db column is :date
param_name = (param_prefix + meth.to_s).to_sym
param = params[param_name]
if use_last_entry_if_param_empty
# If true, use most recent entry from db - for use in settings changing
data = param.empty? ? model.last[meth] : param
else
data = param
end
model_data.send("#{meth}=", data)
end
model_data.save
end
使用参数并发送到方法:
file_name = ("#{params[:expense_date]}_#{params[:expense_time].gsub(/:/, '')}_#{params[:expense_receipt_file][:filename]}")
temp_file = params[:expense_receipt_file][:tempfile]
expense_column_list = [:date,:time,:price,:currency,:description,:source,:receipt_filename]
params[:expense_receipt_filename] = file_name
dm_update(expense_column_list,Expense,params,"expense_",false)
upload(file_name, temp_file, "foo_bucket")
Datamapper类:
class Expense
include DataMapper::Resource
property :id, Serial, :required => true, :key => true
property :date, Date, :required => true
property :time, Time, :required => true, :default => Time.now
property :price, Float, :required => true
property :currency, String, :required => true, :default => "GBP"
property :description, String, :required => true
property :source, String, :required => true
property :receipt_filename, String
end
答案 0 :(得分:0)
好的,当它归结为它时,答案很简单。
我对代码进行了定义,然后逐行完成。
日期参数以yyyy-mm-dd格式存储,时间参数存储为hh:mm。 Datamapper不喜欢那个时间,我在原始版本中已经修复了,但是在重构版本中没有。
修复最终是添加行:
temptime = Time.parse(params[:date] + " " + params[:time])
params[:time] = temptime
在调用dm_update方法之前。这修好了,它现在有用了!