typo代码中trigger.rb有一段代码如下
[code]def remove(pending_item, conditions = { })
return if pending_item.new_record?
conditions_string =
conditions.keys.collect{ |k| "(#{k} = :#{k})"}.join(' AND ')
with_scope(:find => { :conditions => [conditions_string, conditions]}) do
delete_all(["pending_item_id = ? AND pending_item_type = ?",
pending_item.id, pending_item.class.to_s])
end
end[/code]
其中的
[code]conditions_string =
conditions.keys.collect{ |k| "(#{k} = :#{k})"}.join(' AND ')[/code]
生成了类似于(col1=:col1 and col2=:col2)的代码,但是总觉得这种写法可能不对,于是写了一个类似的试验了一下
[code]find(:all,:conditions => [ 'id = :id ', {'id'=>3}])[/code]
果真报错
我知道可以用
[code]find(:all,:conditions => [ 'id = ? ',3])[/code]来解决,但是如果想传入不数量的条件还要改变函数参数,想寻找一种用Hash或者Array实现动态condition参数,不知道该如何实现
[code]def remove(pending_item, conditions = { })
return if pending_item.new_record?
conditions_string =
conditions.keys.collect{ |k| "(#{k} = :#{k})"}.join(' AND ')
with_scope(:find => { :conditions => [conditions_string, conditions]}) do
delete_all(["pending_item_id = ? AND pending_item_type = ?",
pending_item.id, pending_item.class.to_s])
end
end[/code]
其中的
[code]conditions_string =
conditions.keys.collect{ |k| "(#{k} = :#{k})"}.join(' AND ')[/code]
生成了类似于(col1=:col1 and col2=:col2)的代码,但是总觉得这种写法可能不对,于是写了一个类似的试验了一下
[code]find(:all,:conditions => [ 'id = :id ', {'id'=>3}])[/code]
果真报错
我知道可以用
[code]find(:all,:conditions => [ 'id = ? ',3])[/code]来解决,但是如果想传入不数量的条件还要改变函数参数,想寻找一种用Hash或者Array实现动态condition参数,不知道该如何实现