论坛首页 编程语言技术论坛

typo代码的一个疑问,关于conditions中动态参数的查询条件

浏览 3686 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2006-12-30  
typo代码中trigger.rb有一段代码如下
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参数,不知道该如何实现

   发表时间:2006-12-31  
find(:all,:conditions => [ 'id = :id ', {'id'=>3}]) 

这类似吗?
0 请登录后投票
   发表时间: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 '这种查询条件呀?
0 请登录后投票
论坛首页 编程语言技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics