MongoMapper中的update方法

从一个小栗子开始

class Page
  include MongoMapper::Document

  key :title,       String
  key :day_count,   Integer, :default => 0
  key :week_count,  Integer, :default => 0
  key :month_count, Integer, :default => 0
  key :tags,        Array
end

1.increment

增加,用来使给定的key增加相应的值

现在数据库里有两条记录,如下:

> db.pages.find()
{ "_id" : ObjectId("50d30cd943ff68149e000001"), "title" : "111111", "day_count" : 2, "week_count" : 3, "month_count" : 5, "tags" : [ ] }
{ "_id" : ObjectId("50d3e9c843ff681964000001"), "title" : "22222222", "day_count" : 2, "week_count" : 4, "month_count" : 6, "tags" : [ ] }

使用increment

test "test increment" do

    Page.increment({:title => '22222222'}, :day_count => 1, :week_count => 2, :month_count => 3)
    
    @page = Page.find_by_title("111111")
    @page.increment(:day_count => 2, :week_count => 3, :month_count => 5)
    
  end
再看数据库
jury:unit rui$ mongo
MongoDB shell version: 2.2.0
connecting to: test
> db.pages.find()
{ "_id" : ObjectId("50d30cd943ff68149e000001"), "title" : "111111", "day_count" : 4, "week_count" : 6, "month_count" : 10, "tags" : [ ] }
{ "_id" : ObjectId("50d3e9c843ff681964000001"), "title" : "22222222", "day_count" : 3, "week_count" : 6, "month_count" : 9, "tags" : [ ] }
>

2.decrement

就是减去

让我们把上面的数值都减一

test "test decrement" do
    Page.decrement({:title => '22222222'}, :day_count => 1, :week_count => 1, :month_count => 1)
    
    @page = Page.find_by_title("111111")
    @page.decrement(:day_count => 1, :week_count => 1, :month_count => 1)
    
  end
  
end
运行后

结果


3.set

给一个key设值

比如

test "test set" do
  Page.set({:title => '111111'}, :title => "New111111")
end

请仔细比较

另:

@page.set(:title => "New Home")
Page.set({:title => 'Home'}, :title => "New Home")
Page.set(@page.id, @page2.id, :title => "New Home")

4.unset

移除

#@page.unset(:title) 这里只演示第二个 
Page.unset({:title => 'New111111'}, :title) 
#Page.unset(@page.id, @page2.id, :title) 


push

附加一个值到一个数组里

@page.push(:tags => 'foo') 
Page.push({:title => 'Home'}, :tags => 'foo') 
Page.push(@page.id, @page2.id, :tags => 'foo')

push_all

附加若干个值到一个数组里

@page.push_all(:tags => ['foo','bar']) 
Page.push_all({:title => 'Home'}, :tags => ['foo','bar']) 
Page.push_all(@page.id, @page2.id, :tags => ['foo','bar'])

add_to_set, push_uniq

添加一个唯一的值到数组里

@page.add_to_set(:tags => 'foo') 
Page.add_to_set({:title => 'Home'}, :tags => 'foo') 
Page.add_to_set(@page.id, @page2.id, :tags => 'foo') 

pull

从数组里删除一个值

@page.pull(:tags => 'foo') 
Page.pull({:title => 'Home'}, :tags => 'foo') 
Page.pull(@page.id, @page2.id, :tags => 'foo')

pull_all

从数组里删除若干个值

@page.pull_all(:tags => ['foo','bar']) 
Page.pull_all({:title => 'Home'}, :tags => ['foo','bar']
Page.pull_all(@page.id, @page2.id, :tags => ['foo','bar'])

pop

删除数组里最后的元素

@page.pop(:tags => 1) 
Page.pop({:title => 'Home'}, :tags => 1) 
Page.pop(@page.id, @page2.id, :tags => 1)

如果传入的是-1则删除第一个元素

转载于:https://my.oschina.net/u/572987/blog/99760

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值