安徽新华电脑专修学院_安徽电脑培训_安徽电脑培训学校_合肥电脑培训

當前位置:首頁 > 網站舊欄目 > 學習園地 > 設計軟件教程 > 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的不二選擇。
安徽新華電腦學校專業職業規劃師為你提供更多幫助【在線咨詢
主站蜘蛛池模板: 悬挂式小鼠笼架,植物标本采集箱,昆虫标本盒厂家-北京合力科创科技发展有限公司 | 压力机-压装机-黄油机-黄油泵-[广东品嘉灵]专业定制各种精密压装设备 | 正大制管-优质钢管制造商和服务商| 驾驶扫地机-手推洗地机-吸尘器-清洁设备厂家-荣事达官网 | 内蒙古慧申设计顾问有限公司-官网 | 粮食加工设备_玉米_大米_面粉_燕麦_豆类杂粮加工设备-华豫万通 | 内蒙古发电机厂家_呼和浩特发电机租赁_销售_维修_回收_置换|盈弘发电设备有限责任公司 | 尼日利亚SONCAP认证_沙特SABER认证_摩洛哥COC认证-诺帝检测技术(上海)有限公司 | 西安鸿仁汇智软件公司是高新技术企业,专业为企业及高校提供智慧化管理一站式解决方案 | 人民交通网-人民交通杂志官网| 中国(北京)国际园林绿化设备展览会 | 趣看科技-视频新媒体技术一体化专业服务商 | 压力机-压装机-黄油机-黄油泵-[广东品嘉灵]专业定制各种精密压装设备 | 无土栽培|无土栽培技术|水肥一体化|无土栽培蔬菜 | 视频制作_产品宣传片拍摄_二维动画制作公司-深圳火牛传媒 | 弯箍机_钢筋弯箍机_全自动钢筋弯箍机_数控弯箍机-建科智能装备制造(天津)股份有限公司 | 苏州拆除公司_太仓拆除公司_常熟拆除公司_昆山拆除公司--苏州伊诺尔拆除工程有限公司 | 楼宇门厂家-氟碳漆门-不锈钢大门-单元门-锌合金大门-永康市龙卫门业 | 江门市振达机械制造有限公司_散货输送系统_全密封带式输送机 | 指挥调度|调度系统|应急指挥调度|应急指挥|可视化调度|多媒体指挥调度|融合通信|综合调度|应急指挥系统|IP调度系统-北京瑞光极远数码科技有限公司 | 小程序开发,网站建设,APP开发,商城系统开发,社区团购系统开发,区块链溯源,互联网资质办理-软多信息技术有限公司_河南软多信息技术有限公司 | 苏州空气压缩机-无油涡旋空压机-真空泵价格-变频空压机-苏州赫利亚斯气体技术有限公司 | 铝合金线棒生产厂家-提供第三代精益管,防静电工作台定制与批发-宁波杰艾逖仓储设备有限公司 | 郑州离婚律师|婚姻律师在线咨询-河南锦盾律师事务所 | 软化水设备_锅炉软水设备_全自动软化设备【安装维护、更换树脂】-青岛水处理设备厂家 | 景德镇星瑞陶瓷有限公司--官网-景德镇星瑞陶瓷有限公司 | 小型环境空气质量连续监测系统-烟气排放连续监测仪(碳排放)-青岛明德环保仪器有限公司 | 济南牛皮癣专科研究院_「济南市银屑病医院」_济南治牛皮癣医保医院_济南正规的银屑病医院 | 金华银焊条-金华银焊丝-银焊片制造商-银焊环批发商-浙江焊丝生产商-焊环厂家-浙江永旺焊材制造有限公司 | 陕西筱润智能科技有限公司 干部人事智能档案柜 智能密集架 智能档案柜 部队选层文件智能柜 智能枪弹柜 财务智能档案柜 边防武警智能密集架 医院智能档案柜 部队选层文件智能柜智能枪弹柜 学校医院文件柜 企事业单位公检法智能文件柜 生产厂家-筱润智能科技有限公司 RFID射频智能密集架 全自动智能选层档案柜 智能密保柜 枪柜部队营房营具床桌椅办公家具 办公用品档案盒设备货架 全自动智能选层柜生产厂家-筱润智能科技有限公司 | 山东健泽医疗科技有限公司-官网_深呼吸训练器_肋骨固定板_放疗定位膜耗材生产厂家招商 | 南尔智能科技 南尔 小南管家 智慧中控屏 智能语音面板 - 深圳市南尔智能科技有限公司 | 昆山精鑫模具有限公司-模具研发生产 | 一站式服务体验 | 山东鲁控电力设备有限公司_高低压电器设备_变压器 | 活性氧化铝球-活性氧化铝干燥剂厂家价格-3A-5A分子筛-巩义市亿洋水处理材料有限公司 | 景德镇市华信物业管理有限公司 | 中深世纪广告公司 深圳标志设计,深圳logo设计公司,包装设计公司,深圳商标设计,深圳画册设计公司 中商信息网-商务数据网-中文商务数据网 | 深圳激光焊锡机-全自动点胶机设备-全自动激光焊锡机厂家-深圳创精锐 | 厦门公司注册-提供工商登记记账代理服务和营业执照代办地址与注册流程及费用 | 贴膜机厂家|高精度|手机贴膜机|全自动|半自动|无边覆膜机-深圳荷花自动化 | 消防安装_消防安装施工_消防施工_北京消防安装公司-亿杰(北京)消防工程有限公司 |