国产精品一区二区精品_久久小视频_天堂va在线观看_99久久夜色精品国产亚洲96_日本手机在线视频_av成人免费

當前位置:首頁 > 網站舊欄目 > 學習園地 > 設計軟件教程 > sequel,比ActiveRecord更好的ruby數據庫工具

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

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


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

Ruby代碼 復制代碼
  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誤導,find這個本屬于Array的方法的真正含義被忘掉了。寫到這里,就勾起了我在1=>n的時候不能使用user.blogs.find_all{|b| b.comments_per_view > 1}這樣的純ruby語句的傷心往事。

新添兩條數據
Ruby代碼 復制代碼
  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]直接查找出來的結果都是Hash,使用不太方便。Sequel里面也有類,我的程序里面也演示了,如果是CRUD還是類方便一點。


Ruby代碼 復制代碼
  1. class Blog < Sequel::Model   
  2. end  

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

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

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


[]和find工作結果一樣

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


與find(:all)對應的是filer
Ruby代碼 復制代碼
  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}>]  

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

對應的數據庫語句是
Sql代碼 復制代碼
  1. SELECT * FROM countries WHERE region = 'Middle East'    
  2. ORDER BY area DESC LIMIT 5  

初看起來很可怕,但是其實就是
Ruby代碼 復制代碼
  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值得關注,目前是替代ActiveRecord的不二選擇。
安徽新華電腦學校專業職業規劃師為你提供更多幫助【在線咨詢
国产精品一区二区精品_久久小视频_天堂va在线观看_99久久夜色精品国产亚洲96_日本手机在线视频_av成人免费
<button id="0mgmq"><pre id="0mgmq"></pre></button>
  • <tr id="0mgmq"></tr>
  • <abbr id="0mgmq"><source id="0mgmq"></source></abbr> <button id="0mgmq"></button>
  • 国产精品日韩一区二区免费视频| 欧美黄色大片网站| 西西人体一区二区| 欧美日韩亚洲一区| 欧洲亚洲一区二区三区四区五区| 成人av片网址| 香蕉亚洲视频| 亚洲影视在线| 国产精品一二| 日韩亚洲精品在线| 亚洲国产精品毛片| 狠狠色伊人亚洲综合网站色| 亚洲欧美综合| 欧美fxxxxxx另类| 一区二区三区国| 日韩久久不卡| 亚洲高清在线观看一区| 天堂va久久久噜噜噜久久va| 日本亚洲欧洲精品| 日本欧美精品久久久| 日本一区二区三区四区在线观看| 欧美高清性xxxxhd| 欧美下载看逼逼| 亚洲不卡1区| 欧美一区国产在线| 黄色精品免费| 中国成人在线视频| 久久精品五月婷婷| 产国精品偷在线| 久久综合伊人77777麻豆| 欧美少妇一区| 欧美成人久久| 99国产精品久久久久久久成人热| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲经典自拍| 久久精品中文| 精品国产一区二区三区日日嗨| 久久精品一二三区| 亚洲综合欧美日韩| 亚洲五月婷婷| 91在线在线观看| 欧美日韩日本网| 欧美日韩在线精品| 国产日韩欧美一区在线| 成人黄动漫网站免费| 日韩.欧美.亚洲| 在线观看日韩av电影| 性高湖久久久久久久久| 精品国产_亚洲人成在线| 亚洲图片在线观看| 国产精品亚洲综合色区韩国| 国模精品娜娜一二三区| 在线免费观看成人网| 亚洲一区二区三区免费观看| 久久精品国产综合精品| 欧美日韩一区二区三区免费| 国产精品一区二区在线观看| 久久精品美女| 亚洲福利av| 国产一区二区三区av在线| 午夜精品999| 91久久大香伊蕉在人线| 一区二区三区四区免费视频| 亚洲一区综合| 亚洲欧洲在线一区| 久久在线精品| 欧美精选在线| 国产区欧美区日韩区| 狠狠综合久久| 麻豆av一区二区| 夜夜嗨一区二区三区| 日本一区视频在线观看免费| 亚洲美女91| 天堂va久久久噜噜噜久久va| 国产精品久久久久久模特| 视频一区二区三| 免费日韩av片| 欧美视频官网| 国产欧美欧洲| 亚洲影院一区| 国产精品99免费看| 欧美大香线蕉线伊人久久| 久久av一区二区三区亚洲| 欧美日韩国产三区| 久久综合狠狠综合久久综青草| 国产精品嫩草99av在线| 亚洲午夜精品久久久久久浪潮| 3d精品h动漫啪啪一区二区| 国产精品多人| 亚洲a∨一区二区三区| 国产精品一区二区av| 国产农村妇女精品一二区| 欧美黄色大片网站| 日韩国产精品一区二区| 高清日韩一区| 久久亚洲国产精品一区二区| 悠悠资源网久久精品| 亚洲午夜久久久影院伊人| 久久99欧美| 国产欧美一区二区在线播放| 久久久一二三| 六月婷婷一区| 国产日韩一区欧美| 亚洲精品自在在线观看| 欧美日本二区| 欧美日韩国产欧| 欧美一区免费| 一本一本a久久| 翔田千里亚洲一二三区| 欧美大香线蕉线伊人久久| 国产欧美亚洲日本| 国产综合18久久久久久| 国产精品二区二区三区| 成人三级在线| 国产精品一区二区欧美| 国产偷国产偷亚洲高清97cao| 999热视频在线观看| 老司机久久99久久精品播放免费| 国产欧美午夜| 欧美一级播放| yellow视频在线观看一区二区| 51国偷自产一区二区三区的来源| 午夜在线视频观看日韩17c| 米奇777在线欧美播放| 久久久精品动漫| 国产精品日本一区二区 | av观看久久| 国产美女精品久久久| 精品视频一区在线| 日韩欧美在线一区二区| 伊人久久99| 海角社区69精品视频| 国产精品久久久久9999高清| 久久久久久一区| 国产伦理一区二区三区| 日本在线成人一区二区| 欧美精品成人| 午夜一区二区三区不卡视频| 99久久久精品免费观看国产| 久久香蕉综合色| 欧美精品导航| 午夜亚洲性色视频| 久久riav二区三区| 综合视频在线观看| 国产情侣一区| 久久久av水蜜桃| 欧美黄污视频| 国产精品一区二区三区四区五区 | 欧美一区二区三区久久精品| 欧美日韩亚洲三区| 久久久水蜜桃av免费网站| 久久精品ww人人做人人爽| 中文字幕日韩一区二区三区不卡| 亚洲国产精品综合| 狠狠干一区二区| 欧美精品首页| 97神马电影| 欧美88av| 99久久综合狠狠综合久久止| 亚洲国产精品视频一区| 国产亚洲午夜| 日本一区二区在线视频观看| 亚洲理伦在线| 日本在线成人一区二区| 正在播放亚洲| 亚洲精品一区二区毛豆| 欧美一级网站| 一区二区三区四区五区精品| 每日更新成人在线视频| 日韩精品久久一区二区三区| 国产精品一区二区三区免费观看 | 99久热re在线精品视频| 欧美jjzz| 精品国产免费一区二区三区 | 国产精品久久久久久免费观看 | 欧美精品一卡| 精品中文字幕人| 一本色道久久综合亚洲精品不 | 先锋影音亚洲资源| 久久人人97超碰国产公开结果| 一区二区三区偷拍| 99久久精品无码一区二区毛片| 欧美极品一区| 欧美日韩一区二区三区在线视频 | 国产精品国产精品国产专区不卡| 午夜日韩电影| 日韩av一区二区三区在线| 久久久久综合| 99精品国产福利在线观看免费| 色一情一乱一伦一区二区三区| 成人av免费在线看| 亚洲精品麻豆| 亚洲无线视频| 亚洲免费不卡| 欧美日韩日本网| 国产精品免费一区二区三区在线观看| 99热这里只有成人精品国产| 一区二区视频国产| 精品国产综合区久久久久久| 久久久综合网|