标签:
简介:MongoDB[1] 是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。
mongoDB
MongoDB[2] 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。
分布式文件系统(Distributed File System)是指文件系统管理的物理存储资源不一定直接连接在本地节点上,而是通过计算机网络与节点相连。分布式文件系统的设计基于客户机/服务器模 式。一个典型的网络可能包括多个供多用户访问的服务器。另外,对等特性允许一些系统扮演客户机和服务器的双重角色。
HBase是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的Google论文“Bigtable:一个结构化数据的分布式存储系统。
Yonghong Data Mart是基于自有技术研发的一款数据存储、数据处理的软件。Yonghong Data Mart的分布式文件存储系统 (ZDFS)是在Hadoop HDFS基础上进行的改造和扩展,将服务器集群内所有节点上存储的文件统一管理和存储。
以上是对mongoDB的简单介绍,通过介绍要使用MongoDB除了了解他的基本数据存储,还要了解分布式系统如何部署,以及如何解决负载均衡问题。
以下内容是我阅读了菜鸟教程进行的总结,主在熟悉基本命令,了解MongoDB功能特性等.
一. 基本使用以命令方式
use DATABASE_NAME
show dbsshow dbs
db.dropDatabase()
db.user.insert({_id:1,name:’mybo’})
插入语句使用类似json的bson
db.collection.update(
<query>,
<update>,
{
upsert: <boolean>,
multi: <boolean>,
writeConcern: <document>
}
)
参数说明:
Exmple: db.col.update({‘title‘:‘MongoDB 教程‘},{$set:{‘title‘:‘MongoDB‘}},{multi:true})
db.col.save({
"_id" : ObjectId("56064f89ade2f21f36b03136"),
"title" : "MongoDB",
"description" : "MongoDB 是一个 Nosql 数据库",
"by" : "Runoob",
"url" : "http://www.runoob.com",
"tags" : [
"mongodb",
"NoSQL"
],
"likes" : 110
})
db.col.remove({‘title‘:‘MongoDB 教程‘})
删除第一条:db.COLLECTION_NAME.remove(DELETION_CRITERIA,1)
db.col.find()//查询所有
db.col.find({"likes": {$gt:50}, $or: [{"by": "菜鸟教程"},{"title": "MongoDB 教程"}]}).pretty()
$type操作符是基于BSON类型来检索集合中匹配的数据类型,并返回结果。
db.col.find({},{"title":1,_id:0}).limit(2)
{ "title" : "PHP 教程" }
{ "title" : "Java 教程" }
db.col.find({},{"title":1,_id:0}).limit(1).skip(1)
{ "title" : "Java 教程" }
db.COLLECTION_NAME.find().sort({KEY:1})//1 升序 2 降序
b.col.ensureIndex({"title":1})。
18. 聚合
MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果。有点类似sql语句中的 count(*)。
db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$sum : 1}}}])
{
"result" : [
{
"_id" : "w3cschool.cc",
"num_tutorial" : 2
},
{
"_id" : "Neo4j",
"num_tutorial" : 1
}
],
"ok" : 1
}
db.posts.find({post_text:{$regex:"w3cschool.cc",$options:"$i"}})
以上是对mongoDB的命令行操作,但是对于程序员来说一些简单命令操作可以方便我们使用,但是对于作为一个从事java开发人员来说我希望是熟练l了解在java如何调用。
标签:
原文地址:http://www.cnblogs.com/maybo/p/5182277.html