<source id="4vppl"><ins id="4vppl"></ins></source>
<u id="4vppl"><sub id="4vppl"><label id="4vppl"></label></sub></u>
<object id="4vppl"></object>
  • <u id="4vppl"><li id="4vppl"><label id="4vppl"></label></li></u>

    <object id="4vppl"></object>
    <b id="4vppl"><sub id="4vppl"><tr id="4vppl"></tr></sub></b>

      <i id="4vppl"><thead id="4vppl"></thead></i>

      <thead id="4vppl"><li id="4vppl"><label id="4vppl"></label></li></thead>

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

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

      sequel最先讓人眼前一亮的就是sequel命令行工具。在 gem install sequel 以后。執(zhí)行sequel --help,可以看到sequel用法。
      比如在我的blog運(yùn)行過一次,生成了表結(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ù)庫(kù)字段和下載文件中的名字有所不同,需要注意)

      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這個(gè)本屬于Array的方法的真正含義被忘掉了。寫到這里,就勾起了我在1=>n的時(shí)候不能使用user.blogs.find_all{|b| b.comments_per_view > 1}這樣的純r(jià)uby語句的傷心往事。

      新添兩條數(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一點(diǎn)。

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


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

      聲明和ActiveRecord一樣,這也是DataMapper這一點(diǎn)最不受人喜歡的原因。數(shù)據(jù)庫(kù)很靈活,而schema語句永遠(yuǎn)不會(huì)兼容所有數(shù)據(jù)庫(kù)。DataMapper有了這個(gè)死穴,我也沒有關(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)對(duì)應(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的教程都會(huì)提到這一句
      Ruby代碼 復(fù)制代碼
      1. DB[:countries].filter(:region => 'Middle East').order(   
      2. rea.desc).limit(5).all  

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

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

      對(duì)比之下,Sequel里面order不是sql語句,而是ruby style,減少了一些印象分,沒有conditions這么長(zhǎng)的字符串我很滿意,因?yàn)槊看挝叶紩?huì)忘了寫而遇到not valid key region的警告。而order,limit作為獨(dú)立的方法增加了語法可讀性。

      總之,Sequel值得關(guān)注,目前是替代ActiveRecord的不二選擇。
      安徽新華電腦學(xué)校專業(yè)職業(yè)規(guī)劃師為你提供更多幫助【在線咨詢
      国产午夜福三级在线播放_亚洲精品成a人片在线观看_亚洲自慰一区二区三区_久久棈精品久久久久久噜噜
      <source id="4vppl"><ins id="4vppl"></ins></source>
      <u id="4vppl"><sub id="4vppl"><label id="4vppl"></label></sub></u>
      <object id="4vppl"></object>
    1. <u id="4vppl"><li id="4vppl"><label id="4vppl"></label></li></u>

      <object id="4vppl"></object>
      <b id="4vppl"><sub id="4vppl"><tr id="4vppl"></tr></sub></b>

        <i id="4vppl"><thead id="4vppl"></thead></i>

        <thead id="4vppl"><li id="4vppl"><label id="4vppl"></label></li></thead>
        色拍自拍亚洲综合图区 | 中文字幕永久免费视频最新 | 亚洲最大色区在线电影 | 亚洲欧美最新在线网址 | 午夜福利yw在线观看2020 | 中文字幕制服丝袜一区二区 |