sequel最先讓人眼前一亮的就是sequel命令行工具。在 gem install sequel 以后。執行sequel --help,可以看到sequel用法。
比如在我的blog運行過一次,生成了表結構以后,執行
sequel sqlite://blogs.db
得到
- Your database is stored in DB...
- irb(main):001:0>
首先吸引我的就是Sequel中不用聲明類,只需要指定hash key就可以操作表。
(我使用的數據庫字段和下載文件中的名字有所不同,需要注意)
- irb(main):013:0> DB[:blogs].count
- => 0
- irb(main):015:0> DB[:blogs] << {:description => 'just kidin',
- :content => 'nope'}
- => 1
- irb(main):017:0> DB[:blogs].all
- => [{:content=>"nope",
- :description=>"just kidin", :id=>1}]
- irb(main):018:0> DB[:blogs][:id => 1]
- => {:content=>"nope",
- :description=>"just kidin", :id=>1}
- irb(main):019:0> DB[:blogs].find(:id => 1)
- => #<Enumerable::Enumerator:0xb7b792f8>
oops!哪里來的Enumerable?原來受ActiveRecord誤導,find這個本屬于Array的方法的真正含義被忘掉了。寫到這里,就勾起了我在1=>n的時候不能使用user.blogs.find_all{|b| b.comments_per_view > 1}這樣的純ruby語句的傷心往事。
新添兩條數據
- irb(main):035:0> DB[:blogs] << {:description => 'no kidin',
- :content => 'ur kidin'}
- => 2
- irb(main):036:0> DB[:blogs] << {:description => 'good day',
- :content => 'everydays it'}
- => 3
- irb(main):041:0> DB[:blogs].find_all {|b| b[:id] < 3}
- => [{:content=>"nope", :description=>"just kidin",
- :id=>1}, {:content=>"ur kidin",
- :description=>"no kidin", :id=>2}]
這里工作的更像ruby一點。
DB[:blogs]直接查找出來的結果都是Hash,使用不太方便。Sequel里面也有類,我的程序里面也演示了,如果是CRUD還是類方便一點。
- class Blog < Sequel::Model
- end
聲明和ActiveRecord一樣,這也是DataMapper這一點最不受人喜歡的原因。數據庫很靈活,而schema語句永遠不會兼容所有數據庫。DataMapper有了這個死穴,我也沒有關心它的必要了。
Sequel里面也有find,但工作方式是find(:first),而且即使是primary_key也必須寫成hash。
- irb(main):049:0> Blog.find(:id => [2,3])
- => #<Blog @values={:content=>"ur kidin", :description=>"no kidin", :id=>2}>
[]和find工作結果一樣
- irb(main):050:0> Blog[:id => [2,3]]
- => #<Blog @values={:content=>"ur kidin",
- :description=>"no kidin", :id=>2}>
與find(:all)對應的是filer
- irb(main):052:0> Blog.filter(:id => [2,3]).all
- => [#<Blog @values={:content=>"ur kidin", :description=>"no kidin",
- :id=>2}>, #<Blog @values={:content=>"everydays it",
- :description=>"good day", :id=>3}>]
網上介紹Sequel的教程都會提到這一句
- DB[:countries].filter(:region => 'Middle East').order(
- rea.desc).limit(5).all
對應的數據庫語句是
- SELECT * FROM countries WHERE region = 'Middle East'
- ORDER BY area DESC LIMIT 5
初看起來很可怕,但是其實就是
- Country.find(:all, :conditions => {:region => 'Middle},
- :order => 'area desc', :limit => 5)
對比之下,Sequel里面order不是sql語句,而是ruby style,減少了一些印象分,沒有conditions這么長的字符串我很滿意,因為每次我都會忘了寫而遇到not valid key region的警告。而order,limit作為獨立的方法增加了語法可讀性。
總之,Sequel值得關注,目前是替代ActiveRecord的不二選擇。
安徽新華電腦學校專業職業規劃師為你提供更多幫助【在線咨詢】