浏览 3686 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2006-12-30
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 其中的 conditions_string = conditions.keys.collect{ |k| "(#{k} = :#{k})"}.join(' AND ') 生成了类似于(col1=:col1 and col2=:col2)的代码,但是总觉得这种写法可能不对,于是写了一个类似的试验了一下 find(:all,:conditions => [ 'id = :id ', {'id'=>3}]) 果真报错 我知道可以用 find(:all,:conditions => [ 'id = ? ',3])来解决,但是如果想传入不数量的条件还要改变函数参数,想寻找一种用Hash或者Array实现动态condition参数,不知道该如何实现 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2006-12-31
find(:all,:conditions => [ 'id = :id ', {'id'=>3}])
这类似吗? |
|
返回顶楼 | |
发表时间:2006-12-31
alang 写道 find(:all,:conditions => [ 'id = :id ', {'id'=>3}])
这类似吗? conditions_string = conditions.keys.collect{ |k| "(#{k} = :#{k})"}.join(' AND ') 这句话生成的就是'id1 = :id1 AND id2 = :id2 '这种查询条件呀? |
|
返回顶楼 | |