使用Scala操作Mongodb
介绍
Scala是一种功能性面向对象语言。它融汇了很多前所未有的特性。而同一时候又执行于JVM之上。随着开发人员对Scala的兴趣日增,以及越来越多的工具支持,无疑Scala语言将成为你手上一件不可缺少的工具。
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库其中功能最丰富,最像关系数据库的。他支持的数据结构很松散,是类似json的bson格式。因此能够存储比較复杂的数据类型。
Mongo最大的特点是他支持的查询语言很强大,其语法有点类似于面向对象的查询语言,差点儿能够实现类似关系数据库单表查询的绝大部分功能,并且还支持对数据建立索引。
在本文中。我们将介绍使用 Scala
语言怎样与 Mongodb
进行连接与数据处理。
环境安装与配置
第一。 安装Mongodb和Scala,假设已经安装。能够跳过这一步。详细安装步骤请自行搜索。
第二。 安装SBT。SBT是Scala中的构建工具。作用相当于Maven。
安装比較简单,详细步骤请參考:http://www.scala-sbt.org/0.13/tutorial/zh-cn/Setup.html
第三, 等安装完毕后。在控制台运行sbt命令,出现类似下面的信息就能够了:
[root@centos6 scala-project]# sbt
[info] Loading global plugins from /root/.sbt/0.13/plugins
[info] Set current project to Casbah Tutorial (in buildfile:/home/apache/src/scala-project/)
>
第四:创建一个測试项目,并载入Casbah库。Casbah是Mongodb的scala driver
mkdir test-project
cd test-project
vi build.sbt,输入:
name := "Casbah Test"
version := "1.0"
scalaVersion := "2.11.2"
libraryDependencies += "org.mongodb" %% "casbah"% "2.7.3"
注意:build.sbt文件里每行要有一个空行切割。
如有问题请參考http://mongodb.github.io/casbah/guide/installation.html
完毕后输入命令:sbtconsole,第一次执行会自己主动下载casbah及依赖的其他库,载入完毕后例如以下类似例如以下的信息就能够了。
Welcome to Scala version 2.11.2 (Java HotSpot(TM) 64-Bit Server VM,Java 1.7.0_13).
Type in expressions to have them evaluated.
Type :help for more information.
scala>
连接Mongodb
载入scala shell:sbt console
importcom.mongodb.casbah.Imports._
val mongoClient= MongoClient("localhost", 27017)
注意:能够在控制台输入mongoClient. + 空格键,系统会自己主动提示可用的操作。
支持多种连接方式:
1. 简单方式
// Connect to default - localhost, 27017
val mongoClient = MongoClient()
// connect to "mongodb01" host, default port
val mongoClient = MongoClient("mongodb01")
// connect to "mongodb02" host, port 42017
val mongoClient = MongoClient("mongodb02", 42017)
2. URI方式
val uri = MongoClientURI("mongodb://localhost:27017/")
val mongoClient = MongoClient(uri)
3. 支持权限验证方式
//Challenge Response
valserver = new ServerAddress("localhost", 27017)
valcredentials = MongoCredential.createMongoCRCredential(userName, database,password)
valmongoClient = MongoClient(server, List(credentials))
// X.509Protocol
valserver = new ServerAddress("localhost", 27017)
valcredentials = MongoCredential.createMongoX509Credential(userName)
valmongoClient = MongoClient(server, List(credentials))
…
很多其它连接信息,请參考:http://mongodb.github.io/casbah/guide/connecting.html
我们在Mongodb中创建一个test_db的数据库和test collection,并选择简单的用户password方式,例如以下:
val server = newServerAddress("localhost", 27017)
val credentials =MongoCredential.createMongoCRCredential(“user”, “test_db”, “pass”.toArray)
val mongoClient= MongoClient(server, List(credentials))
出现类似例如以下信息即连接成功:
res2:com.mongodb.casbah.MongoClient = com.mongodb.casbah.MongoClient@42143c61
获取数据库和连接:
val db = mongoClient("test_db")
db.collectionNames
val coll = db("test")
增删改查操作
添加
val user1 = MongoDBObject("name"-> "user1")
val user2 = MongoDBObject("name"-> "user2")
coll.insert(user1)
coll.insert(user2)
读取
coll.count() //读取总记录数
也能够使用find读取记录,比方读取全部记录并打印出来:
coll.find().foreach(println)
val query1 =MongoDBObject("name"->"user1")
coll.findOne(query1)
更新
val update1 =MongoDBObject("email"->"user1@test.com")
val result1 = coll.update(query1,update1)
println( "Number updated: " +result.getN )
或者val result = coll.update( query, update, upsert=true )//upsert=true,假设不存在就insert
删除
val query2 = MongoDBObject(“name”->”user2”)
val result2 = coll.remove(query2)
删除集合
coll.drop()
很多其它使用方法请參考casbah的用户文档http://mongodb.github.io/casbah/index.html
版权声明:本文博客原创文章,博客,未经同意,不得转载。
使用Scala操作Mongodb的更多相关文章
- Scala操作MongoDB
Scala操作MongoDB // Maven <dependencies> <dependency> <groupId>org.mongodb</group ...
- Scala对MongoDB的增删改查操作
=========================================== 原文链接: Scala对MongoDB的增删改查操作 转载请注明出处! ==================== ...
- mongoose - 让node.js高效操作mongodb
Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为JavaScript对象以供你在应用中使用. ...
- geotrellis使用(五)使用scala操作Accumulo
要想搞明白Geotrellis的数据处理情况,首先要弄清楚数据的存放,Geotrellis将数据存放在Accumulo中. Accumulo是一个分布式的Key Value型NOSQL数据库,官网为( ...
- 【MongoDB for Java】Java操作MongoDB
上一篇文章: http://www.cnblogs.com/hoojo/archive/2011/06/01/2066426.html介绍到了在MongoDB的控制台完成MongoDB的数据操作,通过 ...
- PHP操作MongoDB学习笔记
<?php/*** PHP操作MongoDB学习笔记*///*************************//** 连接MongoDB数据库 **////*************** ...
- PHP操作Mongodb之增删改查篇
之前,我讲解过PHP中mongodb扩展的安装,及启动,链接操作[忘记了?去看看吧!PHP操作Mongodb之一].本文主要就是讲在PHP中Mongodb的增加,查询,修改及删除数据的操作. 1.增加 ...
- PHP操作Mongodb之高级查询篇
本文主要讲解PHP中Mongodb的除了增删改查的一些其他操作. 在PHP操作Mongodb之增删改查篇中我们介绍了PHP中Mongodb的增加.删除.修改及查询数据的操作.本文主要是将查询时用到的高 ...
- php操作mongodb中的ISODate格式日期
mongodb 中数据记录的日期格式为"dateCreated" : ISODate("2011-12-20T07:22:50.836Z")经过翻阅php官网中 ...
随机推荐
- 于windows建筑物Cocos2d-x win32开发环境
这份文件是从cocos2d-x复制的官网.. . 在windows7上搭建COCOS2D-X开发环境并不难. 可是因为框架更新过快,非常多用户都有困难.我希望你们觉得这个教程实用. 建议:为了避 ...
- bootstrap使用汇总
//大多数功能都能够指定data属性来指定 但是,有必要的情况下使用jquery由于事件是不同的过程 //活动通常有两种状态show shown 通用和过去的 <!DOCTYPE html> ...
- 如何识别SQL Server中的IO瓶颈
原文:如何识别SQL Server中的IO瓶颈 原文出自: http://www.mssqltips.com/sqlservertip/2329/how-to-identify-io-bottlene ...
- 在android移动设备上登录gmail的时候报password错误解决方法!!!!
今天刚发现的解决的方法:就是登录web端的gmail,查看收件箱应该有no-reply这一帐户给你发过邮件(假设没有,你在移动设备上登录一下gmail).照着邮件里的说明去做,就是生成一个专门应用的p ...
- PHP 闭包函数 function use 使用方法实例
/** * @param string $hisStart * @param string $hisEnd * @param int $range * @param string $format * ...
- 采用shell脚本统计代码的行数
刚毕业那会儿有一次去台湾公司面试,我问多行代码怎么写.我从来没有想过这个问题,粗略计算,.惊叹:大概几十万行不行. 最近整理资料,看着eclipse左边全面上市,我觉得这个东西.代码共同拥有的行倒底总 ...
- oracle11g ASM(修复损坏的磁盘组头asm修复2)
--编KFED [oracle@rac2 lib]$cd $ORACLE_HOME/rdbms/lib [oracle@rac2 lib]$ pwd /u01/app/oracle/product/1 ...
- 【关节点+桥】关节点和桥模板 Tarjan
#include <cstdio> #include <cstring> #include <algorithm> using namespace std; con ...
- [Shell]输入參数
获取shell脚本的输入參数,而且推断得到的參数. #!/bin/bash #title: testPT.sh #atuhor: orangleliu #date: 2014-08-08 #desc: ...
- Dos命令将合并两个文本文件的内容
当生产线的问题,有一个放b.txt的内容被添加到a.txt这需要采取.在考虑这个问题.我的第一感觉是敲代码.阅读b.txt内容,渐进写a.txt.想起昨天在加工处理生产线600M决的方法,我用java ...