欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > rails常用數據庫查詢操作、方法淺析

rails常用數據庫查詢操作、方法淺析

熱門標簽:外呼線路從哪里出來的 柯城手機地圖如何做地圖標注 漯河電銷 征服者企業地圖標注 巫師3地圖標注魔力之所 中牟外呼系統違法嗎 淮安自動外呼系統供應商 AI電銷機器人 線路 天津外呼系統怎么收費

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))

3、查詢選項

排序

復制代碼 代碼如下:

#單個排序
Client.all(:order => "created_at ASC")
#多個排序
Client.all(:order => "orders_count ASC, created_at DESC")

返回指定字段

復制代碼 代碼如下:

Client.all(:select => "viewable_by, locked")
#使用函數
Client.all(:select => "DISTINCT(name)")

限定和偏移Limit and Offset

復制代碼 代碼如下:

Client.all(:limit => 5)
#生成
SELECT * FROM clients LIMIT 5
Client.all(:limit => 5, :offset => 5)
#生成
SELECT * FROM clients LIMIT 5, 5

Group分組

復制代碼 代碼如下:

Order.all(:group => "date(created_at)", :order => "created_at")

生成sql
復制代碼 代碼如下:
SELECT * FROM orders GROUP BY date(created_at)

Having
復制代碼 代碼如下:

Order.all(:group => "date(created_at)", :having => ["created_at > ?", 1.month.ago)

生成sql
復制代碼 代碼如下:
SELECT * FROM orders GROUP BY date(created_at) HAVING created_at > '2009-01-15'

只讀

復制代碼 代碼如下:

client = Client.first(:readonly => true)
client.locked = false
client.save
#對只讀對象進行保存將會觸發ActiveRecord::ReadOnlyRecord異常

更新時鎖定記錄

樂觀鎖Optimistic Locking

為使用樂觀鎖,須在表里建一個lock_version的字段,每次更新記錄時,ActiveRecord自動遞增lock_version的值,

復制代碼 代碼如下:

c1 = Client.find(1) c2 = Client.find(1) c1.name = "Michael" c1.save c2.name = "should fail" c2.save # Raises a ActiveRecord::StaleObjectError

備注:You must ensure that your database schema defaults the lock_version column to 0.

This behavior can be turned off by setting ActiveRecord::Base.lock_optimistically = false.

指定樂觀鎖字段名

復制代碼 代碼如下:

class Client ActiveRecord::Base set_locking_column :lock_client_column end

悲觀鎖Pessimistic Locking
悲觀鎖定由數據庫直接提供

復制代碼 代碼如下:

Item.transaction do
    i = Item.first(:lock => true)
    i.name = 'Jones'
    i.save
end

Mysql執行返回
復制代碼 代碼如下:
SQL (0.2ms) BEGIN Item Load (0.3ms) SELECT * FROM `items` LIMIT 1 FOR UPDATE Item Update (0.4ms) UPDATE `items` SET `updated_at` = '2009-02-07 18:05:56', `name` = 'Jones' WHERE `id` = 1 SQL (0.8ms) COMMIT

為特定數據庫加入原始的lock聲明
為Mysql的鎖定聲明為共享模式,即鎖定時仍然可讀

復制代碼 代碼如下:
Item.transaction do  i = Item.find(1, :lock => "LOCK IN SHARE MODE")  i.increment!(:views) end

4、關聯表

復制代碼 代碼如下:

Client.all(:joins => "LEFT OUTER JOIN address ON addresses.client_id = clients.id')

生成sql
復制代碼 代碼如下:
SELECT clients.* FROM clients LEFT OUTER JOIN addresses ON addresses.client_id = clients.id

使用Array、Hash、Named Associations關聯表
有如下model

復制代碼 代碼如下:

class Category ActiveRecord::Base
    has_many :posts
end
class Post ActiveRecord::Base
    belongs_to :category
    has_many :comments
    has_many :tags
end
class Comments ActiveRecord::Base
    belongs_to :post
    has_one :guest
end
class Guest ActiveRecord::Base
    belongs_to :comment
end

復制代碼 代碼如下:

#關聯一個關系
Category.all :joins => :posts
#關聯多個關系
Post.all :joins => [:category, :comments]
#嵌套關聯
Category.all :joins => {:posts => [{:comments => :guest}, :tags]}

為關聯查詢結果設定條件

復制代碼 代碼如下:

time_range = (Time.now.midnight - 1.day)..Time.now.midnight Client.all :joins => :orders, :conditions => {'orders.created_at' => time_ran
#或者
time_range = (Time.now.midnight - 1.day)..Time.now.midnight Client.all :joins => :orders, :conditions => {:orders => {:created_at => time_range}}

5、優化載入
以下代碼,需要執行1 + 10次sql

復制代碼 代碼如下:

clients = Client.all(:limit => 10) clients.each do |client|
    puts client.address.postcode
end

優化:

復制代碼 代碼如下:

clients = Client.all(:include => :address, :limit => 10)
clients.each do |client|
    puts client.address.postcode
end

一次性載入post的所有分類和評論

復制代碼 代碼如下:

Post.all :include => [:category, :comments]

載入category為1的所有post和cooment及tag

復制代碼 代碼如下:

Category.find 1, :include => {:posts => [{:comments => :guest}, :tags]}

6、動態查詢

復制代碼 代碼如下:

Client.find_by_name("Ryan")
Client.find_all_by_name("Ryan")
#!方法,沒有記錄時拋出ActiveRecord::RecordNotFound異常
Client.find_by_name!("Ryan")
#查詢多個字段
Client.find_by_name_and_locked("Ryan", true)
#查詢不到時就創建并保存
Client.find_or_create_by_name(params[:name])
#查詢不到時創建一個實例,但不保存
Client.find_or_initialize_by_name('Ryan')

7、find_by_sql

復制代碼 代碼如下:

Client.find_by_sql("SELECT * FROM clients INNER JOIN orders ON clients.id = orders.client_id ORDER clients.created_at desc")

8、select_all
和find_by_sql類似,但不會用model實例化返回記錄,你會得到一個hash數組

復制代碼 代碼如下:

Client.connection.select_all("SELECT * FROM clients WHERE id = '1'")

9、判斷記錄是否存在

復制代碼 代碼如下:

#通過id來查詢
Client.exists?(1)
Client.exists?(1, 2, 3)
#or
Client.exists?([1,2,3])
#通過其他條件來查詢
Client.exists?(:conditions => "first_name = 'Ryan'")
#沒有參數時,則:表是空的 ? false : true
Client.exists?

10、計算

復制代碼 代碼如下:

#求結果集條數
Client.count(:conditons => "first_name = 'Ryan'")
#求某個字段非空白的條數
Client.count(:age)
#平均值
Client.average("orders_count")
#求最小值
Client.minimum("age")
#求最大值
Client.maximum("age")
#求和
Client.sum("orders_count")

您可能感興趣的文章:
  • Ruby連接使用windows下sql server數據庫代碼實例
  • 在Ruby程序中連接數據庫的詳細教程
  • Ruby中訪問SQL Server數據庫的配置實例
  • ruby+nokogori抓取糗事百科前10頁并存儲進數據庫示例
  • 淺談Ruby on Rails下的rake與數據庫數據遷移操作

標簽:河池 南昌 內江 棗莊 甘孜 克拉瑪依 西雙版納 大慶

巨人網絡通訊聲明:本文標題《rails常用數據庫查詢操作、方法淺析》,本文關鍵詞  rails,常用,數據庫,查詢,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《rails常用數據庫查詢操作、方法淺析》相關的同類信息!
  • 本頁收集關于rails常用數據庫查詢操作、方法淺析的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    国产精品理伦片| 久久发布国产伦子伦精品| 中文字幕丰满孑伦无码专区| 欧美日韩一区二区三区不卡 | 欧美亚日韩国产aⅴ精品中极品| 国产精品入口麻豆九色| 国产一区二区三区免费| 国产全是老熟女太爽了| 日韩美女一区二区三区| 免费一级欧美片在线观看| 精品人妻少妇嫩草av无码| 欧美精品99久久久**| 亚洲国产视频网站| 精品人妻在线视频| 欧美一区二区三区色| 偷拍与自拍一区| 中文在线永久免费观看| 日韩视频123| 久久国产婷婷国产香蕉| 亚洲午夜精品久久久久久高潮| 欧美精品一区二区三区视频| 久99久精品视频免费观看| 日本欧美一区二区三区不卡视频| 久久久三级国产网站| 国产成人av自拍| 色综合久久综合网欧美综合网| 亚洲欧美偷拍三级| 亚洲精品成人无码毛片| 欧美福利一区二区| 青青草国产成人99久久| 五月婷婷欧美激情| 亚洲欧洲日韩在线| 国产黄色一区二区三区| 91精品婷婷国产综合久久竹菊| 蜜桃一区二区三区四区| 99re6热在线精品视频| 综合久久给合久久狠狠狠97色| 91美女视频网站| 欧美电影在线免费观看| 六月丁香综合在线视频| 久久久久久久久久97| 伊人夜夜躁av伊人久久| 亚洲视频在线播放免费| 久久这里只有精品6| 成人免费视频caoporn| 欧美色视频在线观看| 男男成人高潮片免费网站| 日韩视频在线观看免费视频| 亚洲日本中文字幕区| 色哟哟无码精品一区二区三区| 欧美不卡在线视频| 成人午夜电影网站| 欧美日韩电影在线播放| 经典一区二区三区| 日本电影欧美片| 免费成人你懂的| 亚洲成人生活片| 亚洲成人动漫一区| 99国产精品免费| 亚洲美女屁股眼交3| 人妻丰满熟妇aⅴ无码| 国产精品视频免费看| 天天躁日日躁狠狠躁av| 国产欧美精品一区| 日本精品一二三| 国产视频一区二区在线观看| 久久精品无码一区二区三区毛片 | 91免费观看在线| 亚洲精品在线一区二区| 成人性生交大片免费看中文| 91精品国产一区二区三区 | 精品黑人一区二区三区久久| 成人丝袜高跟foot| 欧美tickling网站挠脚心| 成人91在线观看| 精品少妇一区二区三区日产乱码| 成人午夜精品在线| 欧美va在线播放| 91麻豆自制传媒国产之光| 久久亚洲精精品中文字幕早川悠里 | 亚洲成人精品一区二区| 91av手机在线| 日本不卡视频一二三区| 日韩成人黄色片| 久久91精品久久久久久秒播| 欧美天天综合网| 国产一区二区三区四区五区美女 | 久久国内精品视频| 欧美午夜影院一区| 国产91丝袜在线18| 日韩美女视频在线| 野花视频免费在线观看| 国产精品嫩草99a| b站大片免费直播| 亚洲123区在线观看| 一本大道综合伊人精品热热| 国产资源精品在线观看| 日韩精品专区在线影院重磅| 中文字幕人妻熟女在线| 1000部国产精品成人观看| 精品成人无码一区二区三区| 亚洲成人先锋电影| 日本精品一区二区三区高清| 国产99久久久国产精品潘金网站| 2023国产精品| 人妻丰满熟妇aⅴ无码| 亚洲成av人影院在线观看网| 色婷婷综合久久久久中文| 国产成人在线视频播放| 久久综合九色综合欧美就去吻| 星空大象在线观看免费播放| 亚洲黄色免费电影| 在线免费av一区| 成人网男人的天堂| 欧美激情一区在线观看| 成人午夜福利一区二区| 日本欧美一区二区三区乱码| 欧美高清视频在线高清观看mv色露露十八 | 免费成人深夜夜行p站| 亚洲国产日韩综合久久精品| 欧美影片第一页| 中文字幕在线观看视频www| 日韩美女视频一区| 色综合久久久久网| 大白屁股一区二区视频| 国产夜色精品一区二区av| 黄色免费一级视频| 国内一区二区在线| 久久久久久久一区| 人妻熟人中文字幕一区二区| 国产精品影视在线观看| 国产日韩精品一区二区三区 | 亚洲一级片在线观看| 色噜噜狠狠成人网p站| 波多野结衣一区二区三区| 亚洲视频在线一区二区| 在线视频观看一区| 日韩大尺度视频| 亚洲成在人线免费| 日韩一区二区在线观看视频 | 亚洲男同1069视频| 欧美午夜电影网| 在线免费看黄色片| 日韩精品久久理论片| 欧美va亚洲va香蕉在线 | 丝瓜av网站精品一区二区| 欧美丰满少妇xxxbbb| 捆绑裸体绳奴bdsm亚洲| 蜜桃视频第一区免费观看| 久久亚洲捆绑美女| 视频国产一区二区| 91蝌蚪porny| 日韩高清中文字幕一区| 精品粉嫩超白一线天av| 五月天免费网站| 99久久精品情趣| 亚洲不卡一区二区三区| 欧美成人国产一区二区| 国产第一页精品| 99精品视频中文字幕| 亚洲图片一区二区| 欧美精品一区二区三区一线天视频| 亚洲色图27p| 91麻豆视频网站| 日韩av电影天堂| 国产婷婷色一区二区三区在线| 一本一道波多野结衣一区二区| 亚洲成a人无码| 久久激五月天综合精品| 中文字幕不卡的av| 欧美久久久久久久久| 日本二区在线观看| av电影在线观看不卡| 婷婷中文字幕综合| 久久免费视频色| 91国产福利在线| av在线网站观看| 国产盗摄精品一区二区三区在线| 亚洲免费观看高清完整版在线观看熊| 欧美一激情一区二区三区| 免费看一级黄色| 韩国一区二区三区四区| 久久99蜜桃精品| 亚洲精选免费视频| 欧美r级在线观看| 色综合婷婷久久| 少妇毛片一区二区三区| 成人av资源下载| 男人的天堂亚洲一区| 国产精品久99| 欧美大片在线观看一区二区| 色网站国产精品| 欧美 日韩 国产 成人 在线观看 | 久久久久久久久久久久久女过产乱| 水蜜桃av无码| 成人性生交大合| 久久精品国产亚洲一区二区三区| 亚洲精品欧美在线| 久久久精品国产免大香伊| 8x8x8国产精品|