1、獲取數據
獲取第一條、最后一條記錄
代碼如下:
Model.first
Model.first(options)
Model.find(:first, options)
Model.last
Model.last(options)
Model.find(:last, options)
通過id獲取記錄
代碼如下:
Model.find(1, 10, options)
Model.find([1, 10], options)
.find all
代碼如下:
Model.all(options)
對一組數據進行相同操作
代碼如下:
User.all.each do |user|
NewsLetter.weekly_deliver(user)
end
如果表記錄數比較大,這種方式比較耗資源,因為它會一次載入整個表的數據。改用以下這種方式,它每次只載入1000行,然后逐步yield完整個表
代碼如下:
User.find_each do |user|
NewsLetter.weekly_deliver(user)
end
自定義方式,find_each接受和find同樣的options
代碼如下:
User.find_each(:batch_size => 5000, :start => 2000) do |user|
NewsLetter.weekly_deliver(user)
end
find_in_batches,和find_each相似,但它yield時傳遞的是model對象數組,而不是單個model對象
代碼如下:
Invoice.find_in_batches(:include => :invoice_lines) do |invoices|
export.add_invoices(invoices)
end
2、查詢條件
通過替換?來傳遞條件值,可避免SQL注入
代碼如下:
Client.first(:conditions => ["orders_count = ?", params[:orders])
symbol占位條件
代碼如下:
Client.all(:conditions => ["created_at >= :start_date AND created_at <= :end_date", {:start_date => params[:start_date], :end_date => params[:end_date] }])
范圍條件 in(集合)
代碼如下:
Client.all(:conditions => ["created_at IN (?)", (params[:start_date].to_date)..(params[:end_date].to_date])
生成sql
代碼如下:
SELECT * FROM users WHERE (created_at IN ('2007-12-31','2008-01-01','2008-01-02','2008-01-03','2008-01-04','2008-01-05', '2008-01-06','2008-01-07','2008-01-08'))
如果要生成日期時間,再加上.to_time
代碼如下:params[:start_date].to_date.to_time,生成2007-12-01 00:00:00格式
有上數據庫會在以上條件中報錯,如Mysql會報查詢語句過長的錯誤,此時可以改成created_at > ? AND created_at < ?的形式
Hash條件
代碼如下:
Client.all(:conditions => {:locked => true })
帶范圍條件
代碼如下:
Client.all(:conditons => {:created => (Time.now.midnight - 1.day)..Time.now.midnight})
生成sql
代碼如下:
SELECT * FROM clients WHERE (clients.created_at BETWEEN '2008-12-21 00:00:00' AND '2008-12-22 00:00:00')
集合條件
代碼如下:
Client.all(:conditons => {:orders_count => [1,3,5])
生成sql
代碼如下:
SELECT * FROM clients WHERE (clients.orders_count IN (1,3,5))
新聞熱點
疑難解答