mongo_mapper&ruby

Mongomapper 用户mongo数据库配置,以及其提供了很多mongo的方法,可以很好地用来 对mongo相关封装和操作。

环境准备:gem install mongo_mapper

和activerecord很类似。将mongo的collection(表)和 类一一对应。

mongo_mapper 网上方法资源:http://mongomapper.com/documentation/plugins/querying.html

1、mongo配置从yml文件中读取

mongo55:
host: ***
port: ***
database: ****

2、mongo collection封装:

1)初始化mongo数据库连接

2)将需要的collections name 以类形式封装

#encoding:utf-8
require 'active_model'
require 'mongo'
require 'mongo_mapper'

=begin
author: kanlijun
date: 2016/07/13
description: 使用mongo_mapper模块实现collections封装,统一调配;初始化mongo连接,定义表和类对应关系
=end
class ConnectMongo
def initialize(host,port,database)
MongoMapper.connection =Mongo::Connection.new(host,port)
MongoMapper.database=database
end
end
#mobile
class Mobile
include MongoMapper::Document

set_collection_name 'mobile'
end

#ncontacts
class Ncontact
include MongoMapper::Document

end

3、调用rb文件案例:

1)读取yml配置数据,并初始化;

2)使用mongo_mapper的mongo操作方法

#encoding:utf-8
require 'mongo_mapper'
require_relative '../source/core/mongodb'

DATA_PATH='../source/data/mongo.yml'
mongo = YAML.load(File.open(DATA_PATH))
db =mongo['mongo55']
host,port,database =db['host'],db['port'],db['database']
ConnectMongo.new(host,port,database)

mobile = Mobile.all(:anion=>'789757')
puts mobile[0]['de']
puts mobile.length

#条件搜索排序
nsms = Nsms.where(:urr=>'789757').sort(:time.desc).all
puts nsms[1]['p']
lim =Nsms.first
# puts lim
puts lim['urr']

#排序
mo= Nsms.sort(:time.desc).first
puts mo['urr']

#随机拿出几个
mo= Nsms.limit(3).all
puts mo[0]['urr']
puts mo[2]['urr']

count = Nsms.where(:urr=>'789757').count

puts "count:#{count}" 

ruby&mongo_mapper的更多相关文章

  1. 安装cocoapods遇到两大坑-Ruby版本升级和Podfile的配置

    今天安装cocoapods #移除原有ruby源 $ gem sources --remove https://rubygems.org/ #使用可用的淘宝网 $ gem sources -a htt ...

  2. Unable to download data from http://ruby.taobao.org/ & don't have write permissions for the /Library/Ruby/Gems/2.0.0 directory.

    安装cocoapods,记录两个问题! 1.镜像已经替换成了 http://ruby.taobao.org/, 还是不能不能安装cocoapods, 报错:Unable to download dat ...

  3. 安装了ruby后怎么安装sass

    在命令行中输入 ruby -v 查看版本号 先移除默认的https://rubygems.org源,命令为gem sources --remove https://rubygems.org/,按回车 ...

  4. ruby 基础知识(一)

    突然今天发现一大神的博客:http://www.cnblogs.com/jackluo/archive/2013/01/22/2871655.html    相信初学者会受益颇多 ruby  参考文档 ...

  5. ruby 基础知识(二)

    ruby  中的动态方法 http://singleant.iteye.com/blog/1680382 Rails 大量使用了符号(symbol).符号看上去很像变量名,不过以冒号作为前缀.符号的例 ...

  6. Ruby安装Scss

    Ruby安装Scss 引言 已经许久不写HTML了,今天有点以前的东西要改.但是刚装的Windows10,已经没有以前的Web开发环境了.只好重新安装. 结果Webstorm装好后配置Scss出现错误 ...

  7. fzf by ruby

    fzf by ruby */--> fzf by ruby 1 github地址 https://github.com/junegunn/fzf 2 简介 软件通过匿名管道和grep扩展了bas ...

  8. The Safe Navigation Operator (&.) in Ruby

    The most interesting addition to Ruby 2.3.0 is the Safe Navigation Operator(&.). A similar opera ...

  9. Ruby on Rails 创建https应用

    1. 创建证书请求文件条件:私钥+证书签名请求+opensslyum install -y opensslmkdir /root/ssl/ && cd /root/ssl/openss ...

随机推荐

  1. oracle job create table insert into

    create or replace procedure proc_tzyj is begin insert into t_trade_activity@dw3_link.regress.rdbms.d ...

  2. Cisco IOS IP Service Level Agreementv (IP SLA)

    Responder and Control Protocol 1.Responder内嵌在思科目标路由器中的一个组件,用来对IP SLA请求包做应答,通过对应达包添加时间戳属性,以提高测量计算的准确性 ...

  3. Linux服务器数据库的导入和导出

    一.导出: 用mysqldump命令行 命令格式 mysqldump -u 用户名 -p 数据库名 > 数据库名.sql 范例: mysqldump -u root -p abc > ab ...

  4. 贪心算法 hdu 1009

    1.因为要排序只派j[i]/f[i],不能知道f[i]和j[i]各自排序后的顺序,因此要用到结构体 2.用sort(ware,ware+n,cmp) cmp 为俩个数组的元素比较大小的布尔值 #inc ...

  5. Windows Store App 全球化:在后台代码中引用字符串资源

    上文提到了引用字符串资源具有两种方式,分别是在XAML元素中和在后台代码中引用资源文件中的字符串资源.在第一小节已经介绍了如何在XAML元素中引用字符串资源,本小节将讲解在后台代码中引用字符串资源的相 ...

  6. BestCoder Round #43

    T1:pog loves szh I(hdu 5264) 题目大意: 给出把AB两个字符串交叉拼起来的结果,求出原串. 题解: 不解释..直接每次+2输出. T2:pog loves szh II(h ...

  7. IBatis.Net XML文件配置

    一.添加Provider.config <?xml version="1.0" encoding="utf-8"?> <providers x ...

  8. 排序小结(C++版)

    一.快速排序 #include <iostream> using namespace std; int adjust(int a[],int start,int end) { int i, ...

  9. 立即调用的函数表达式IIFE

    1.写法 (function () { alert("IIFE");})();//或者(function () { alert("IIFE"); }());

  10. Oracle Metadata Management (OMM)元数据管理 12.2.1发布

    元数据管理元数据管理是解决大量关键业务和技术挑战的基础,这些挑战包括元数据实体有多少,上游数据变化的影响,在浏览器中提供友好的分析展现界面,或提供企业范围内的元数据现状分析和改进视图.OMM是一款基于 ...