Heroku経由でSinatraを使ってみているのですが、ModelとしてSequelを使ってみることにしました。

###Userクラスを作る
DBをオンメモリにしておいて、テーブル作成・クラスの宣言
shell>>
% irb
require 'rubygems'
require 'sequel'

DB = Sequel.sqlite
DB << "CREATE TABLE users (id INTEGER PRIMARY KEY, name VARCHAR(255) not NULL)"

class User < Sequel::Model
end
<<--

これから、User.なんとかでデータの作成などできます。

shell>>
User.create(:name => 'satoko')

User.find(:name => 'satoko')
User.find(:id => 1).update(:name => 'satoko')
User.find(:id => 1).delete
User.first

User.all
=> [#<User @values={:name=>"satoko", :id=>1}>]

DB[:users].filter(:name => 'satoko').sql
=> "SELECT * FROM users WHERE (name = 'satoko')"
<<--

###findは1件操作なので、複数件の場合はfilterで行う
shell>>
User.filter("id > ?", 0).limit(10).each {|u| p[:name]}
=> #<Sequel::SQLite::Dataset: "SELECT * FROM users WHERE (id > 0)">
<<--

また、@orepuriさんに教えてもらったのですが、all、first、eachなどがあって初めてSQLが発行されるそうで、なかなか面白いです

###References
Sequel概要(2年前の資料なので、コード的には古いかもしれません)
http://www.slideshare.net/zhesto/ruby-off-rails-japanese

チートシート
http://sequel.rubyforge.org/rdoc/files/doc/cheat_sheet_rdoc.html
http://cheat.errtheblog.com/s/sequel/

Classリファレンス:ModelやDatasetなど
http://sequel.rubyforge.org/documentation.html

posted by satoko satoko on Wed 16 Sep 2009 at 21:30 with 0 comments
Contents rssrss
NSAssertやNSLogを無効にする:-DNS_BLOCK_ASSERTIONS=1とNS_BLOCK_ASSERTIONS
GDBでview.frameを表示させる
Core Animationについてのリンク集
[iPhone] new BSDライセンスについてライセンス引用のメモ
Implementing a Container View Controller in UIViewController Class Reference
UITableView用のNSIndexPathの作り方
Xcodeのテンプレート、View-based ApplicationとWindow-based Applicationの違い
CopyOnSelectのLion対応
Xcode4のCode Snippetsを別のPCに移動する+gitで管理する
[iPhone] Singleton: iOS4以降はGCDのdispatch_onceを使う
Tags
ruby
Comments rssrss
KingofSmack KingofSmack: Here also good reads for this mobile application d... 05/10 18:02
satoko satoko: stackoverflowでも同じエラーを挙げている人がいたので、1.3でアップロードしたよってコメ... 12/13 03:36
ujihisa ujihisa: :%s/blog/glob/g 07/28 16:41
satoko satoko: しゅが〜様 返事が遅くなって申し訳ありません。また、投稿百景ご購入ありがとうございます。 『po... 10/11 14:05
しゅが~ しゅが~: こんにちは。投稿百景を発売日翌日から利用しています。本当にいいAppを作っていただきました。罫線絵文... 10/08 00:38
satoko satoko: 情報ありがとうございます!コミットを再利用するの部分、文章が不明瞭ですね。ちょっと修正します。教えて... 09/25 14:32
ono ono: 後で確認したら、ファイルの除外はamendではできないですね、失礼しました。alias は、'-C ... 09/25 10:47
satoko satoko: ぉぉ了解です。ありがとうございます〜 モヤが消えました! 03/13 16:31