日本一区二区免费播放_麻豆导航_久久精品99_国产性av_色婷婷噜噜久久国产精品12p_av福利资源_精品综合久久

當(dāng)前位置:首頁 > 網(wǎng)站舊欄目 > 學(xué)習(xí)園地 > 設(shè)計軟件教程 > sequel,比ActiveRecord更好的ruby數(shù)據(jù)庫工具

sequel,比ActiveRecord更好的ruby數(shù)據(jù)庫工具
2010-01-13 22:59:47  作者:  來源:
單文件blog應(yīng)用中,我已經(jīng)展示了sequel的使用。sequel在介紹sinatra和rest-client的視頻中,有過推薦,本篇文章簡要介紹sequel和datamapper以及activerecord的區(qū)別。

sequel最先讓人眼前一亮的就是sequel命令行工具。在 gem install sequel 以后。執(zhí)行sequel --help,可以看到sequel用法。
比如在我的blog運行過一次,生成了表結(jié)構(gòu)以后,執(zhí)行
sequel sqlite://blogs.db
得到
Ruby代碼 復(fù)制代碼
  1. Your database is stored in DB...   
  2. irb(main):001:0>  


首先吸引我的就是Sequel中不用聲明類,只需要指定hash key就可以操作表。
(我使用的數(shù)據(jù)庫字段和下載文件中的名字有所不同,需要注意)

Ruby代碼 復(fù)制代碼
  1. irb(main):013:0> DB[:blogs].count   
  2. => 0   
  3. irb(main):015:0> DB[:blogs] << {:description => 'just kidin',   
  4.  :content => 'nope'}   
  5. => 1   
  6. irb(main):017:0> DB[:blogs].all   
  7. => [{:content=>"nope",   
  8.  :description=>"just kidin":id=>1}]   
  9. irb(main):018:0> DB[:blogs][:id => 1]   
  10. => {:content=>"nope",   
  11.  :description=>"just kidin":id=>1}   
  12. irb(main):019:0> DB[:blogs].find(:id => 1)   
  13. => #<Enumerable::Enumerator:0xb7b792f8>  

oops!哪里來的Enumerable?原來受ActiveRecord誤導(dǎo),find這個本屬于Array的方法的真正含義被忘掉了。寫到這里,就勾起了我在1=>n的時候不能使用user.blogs.find_all{|b| b.comments_per_view > 1}這樣的純ruby語句的傷心往事。

新添兩條數(shù)據(jù)
Ruby代碼 復(fù)制代碼
  1. irb(main):035:0> DB[:blogs] << {:description => 'no kidin',   
  2.  :content => 'ur kidin'}   
  3. => 2   
  4. irb(main):036:0> DB[:blogs] << {:description => 'good day',   
  5.  :content => 'everydays it'}   
  6. => 3   
  7.   
  8. irb(main):041:0> DB[:blogs].find_all {|b| b[:id] < 3}   
  9. => [{:content=>"nope":description=>"just kidin",   
  10.  :id=>1}, {:content=>"ur kidin",   
  11.  :description=>"no kidin":id=>2}]  

這里工作的更像ruby一點。

DB[:blogs]直接查找出來的結(jié)果都是Hash,使用不太方便。Sequel里面也有類,我的程序里面也演示了,如果是CRUD還是類方便一點。


Ruby代碼 復(fù)制代碼
  1. class Blog < Sequel::Model   
  2. end  

聲明和ActiveRecord一樣,這也是DataMapper這一點最不受人喜歡的原因。數(shù)據(jù)庫很靈活,而schema語句永遠(yuǎn)不會兼容所有數(shù)據(jù)庫。DataMapper有了這個死穴,我也沒有關(guān)心它的必要了。

Sequel里面也有find,但工作方式是find(:first),而且即使是primary_key也必須寫成hash。

Ruby代碼 復(fù)制代碼
  1. irb(main):049:0> Blog.find(:id => [2,3])   
  2. => #<Blog @values={:content=>"ur kidin", :description=>"no kidin", :id=>2}>  


[]和find工作結(jié)果一樣

Ruby代碼 復(fù)制代碼
  1. irb(main):050:0> Blog[:id => [2,3]]   
  2. => #<Blog @values={:content=>"ur kidin",   
  3.  :description=>"no kidin":id=>2}>  


與find(:all)對應(yīng)的是filer
Ruby代碼 復(fù)制代碼
  1. irb(main):052:0> Blog.filter(:id => [2,3]).all   
  2. => [#<Blog @values={:content=>"ur kidin", :description=>"no kidin",   
  3.  :id=>2}>, #<Blog  @values={:content=>"everydays it",    
  4. :description=>"good day":id=>3}>]  

網(wǎng)上介紹Sequel的教程都會提到這一句
Ruby代碼 復(fù)制代碼
  1. DB[:countries].filter(:region => 'Middle East').order(   
  2. rea.desc).limit(5).all  

對應(yīng)的數(shù)據(jù)庫語句是
Sql代碼 復(fù)制代碼
  1. SELECT * FROM countries WHERE region = 'Middle East'    
  2. ORDER BY area DESC LIMIT 5  

初看起來很可怕,但是其實就是
Ruby代碼 復(fù)制代碼
  1. Country.find(:all:conditions => {:region => 'Middle},    
  2. :order => 'area desc':limit => 5)  

對比之下,Sequel里面order不是sql語句,而是ruby style,減少了一些印象分,沒有conditions這么長的字符串我很滿意,因為每次我都會忘了寫而遇到not valid key region的警告。而order,limit作為獨立的方法增加了語法可讀性。

總之,Sequel值得關(guān)注,目前是替代ActiveRecord的不二選擇。
安徽新華電腦學(xué)校專業(yè)職業(yè)規(guī)劃師為你提供更多幫助【在線咨詢
主站蜘蛛池模板: 一级视频在线 | 色日本在线 | 欧美肥胖老太bbw | 男女xx00大尺度动态 | 欧美1卡一卡二卡三新区 | 天天操夜夜操天天操 | 亚洲天天综合色制服丝袜在线 | 国产图区| 69av视频在线 | 国产全黄三级国产全黄三级书 | 日本人视频18jizz免费 | 日本免费不卡一区 | 欧美xxxx新一区二区三区 | 久久久久久国产精品mv | 中文字幕第一区 | 经典欧美gifxxoo动态图午夜 | 国产高清美女一级a毛片 | 国产v片成人影院在线观看 国产v亚洲v天堂无码 | 日本免费一区二区在线观看 | 免费日韩在线视频 | 看全色黄大色黄大片免责看的 | 黄a级| 中文字幕在线看片成人 | 国产精品第3页 | 久操资源 | 美国一区二区三区 | 国产剧情演绎在线观看视频 | 国产无遮挡又黄又爽高清视 | 日本一区二区视频在线 | 免费澳门一级毛片 | 国产亚洲精品看片在线观看 | 日本www黄| 三级大片在线观看 | 日本综合视频 | 99精品免费观看 | a亚洲视频 | 欧美日韩亚洲视频 | 亚洲欧美日韩中文不卡 | 国产精品第12页 | 久久精品一区二区三区不卡牛牛 | 九九精品国产99精品 |