设为首页 收藏本站
查看: 594|回复: 0

[经验分享] MongoDB权威指南(1)- Getting Started

[复制链接]

尚未签到

发表于 2015-7-6 10:02:24 | 显示全部楼层 |阅读模式
  最近公司考虑重构数据,因为数据比较复杂,我觉得mongoDB是个非常合适的选择,就了解了一下,
  一看之下,嘿,还挺有意思,所以就有了这个系列的读书笔记,如果有什么不当,请不吝指出。
  另外,有些专用的词汇我没有翻译,一个是不好翻译,另外是我觉得翻译了反而会妨碍理解。
  本书电子书下载链接 http://download.iyunv.com/source/3399006
  mongoDB下载链接 http://www.mongodb.org/downloads
  --------------------------------------------------------------------------------------------------------------
  安装
  解压缩出来就OK了,mongoDB缺省使用磁盘根目录的data文件夹和data\db文件夹,
  这两个文件夹需要手工建立,如果想使用其他路径,那么启动mongoDB的时候需要指明路径
  运行
  运行CMD打开控制台窗口,导航至mongodb的bin目录,运行mongod.exe,服务器就启动起来了,按ctrl-c结束程序。
  另开一个控制台窗口,导航至mongodb的bin目录,运行mongo.exe来启动shell,就链接到服务器了,缺省连接到test数据库。
  -------------------------------------------------------------------------------------------------------------
  OK,第一章讲mongoDB如何如何牛b的我们就隔过去啦,这里直接是第二章。
  1.一些基本概念
  document :mongoDB里边数据的基本单位,相当于关系数据库里的行
  collection: 相当于关系数据库的表,不过是没有数据结构定义的
  每个mongoDB的实例可以运行多个database,每个database有自己的collection和权限控制
  mongoDB拥有一个强大的javascript shell,用于管理数据库和操作数据
  每个document都有一个特殊的key:"_id",这个值在collection内是唯一的
  document
  document是一组有序的key/value对,使用json风格的数据。



{"foo" : 3, "greeting" : "Hello, world!"}

  key是个UTF-8字符串,value 可以是很多类型,甚至是一个嵌入的document。
  collection
  collection是一组document,它是无结构定义的,所以你可以把任何document存入一个collection里。
  subcollection
  一个习惯性的组织collection的方式,使用.号分隔,像命名空间。例如,程序里使用了一个blog,它可能包含一个collection叫blog.post和另外一个collection叫blog.authors,这仅仅是出于组织内容的目的,它们俩看起来像是blog的子集,实际上他们没有任何关系,甚至blog也许就是不存在的。
  database
  一个mongoDB的实例可以运行多个database,database之间是完全独立的,每个database有自己的权限,每个database存储于磁盘的不同文件。
  2. mongoDB shell
  shell本身就是一个javascript解释器,让我们来干点啥来看看
  可以进行数学运算




> x = 200
200
> x / 5;
40  可以使用标准的javascript库




> Math.sin(Math.PI / 2);
1
> new Date("2010/1/1");
"Fri Jan 01 2010 00:00:00 GMT-0500 (EST)"
> "Hello, World!".replace("World", "MongoDB");
Hello, MongoDB!  甚至可以定义javascript函数




> function factorial (n) {
... if (n  factorial(5);
120  能够执行javascript确实很cool,当然这不是shell的全部功能。


  • 使用use命名切换数据库




> use foobar
switched to db foobar  然后就可以查看db变量来看看当前数据库是啥




> db
foobar

  • 使用insert函数想collection插入document
  先创建一个本地变量叫post




> post = {"title" : "My Blog Post",
... "content" : "Here's my blog post.",
... "date" : new Date()}
{
"title" : "My Blog Post",
"content" : "Here's my blog post.",
"date" : "Sat Dec 12 2009 11:23:21 GMT-0500 (EST)"
}  然后把它插入到叫blog的collection里边去




> db.blog.insert(post)  然后我们可以用find函数看看blog里边的内容




> db.blog.find()
{
"_id" : ObjectId("4b23c3ca7525f35f94b60a2d"),
"title" : "My Blog Post",
"content" : "Here's my blog post.",
"date" : "Sat Dec 12 2009 11:23:21 GMT-0500 (EST)"
}  里边自动加了个叫"_id"的key。


  • find返回collection里的书有document,如果只想查看一个使用findone



    > db.blog.findOne()
    {
    "_id" : ObjectId("4b23c3ca7525f35f94b60a2d"),
    "title" : "My Blog Post",
    "content" : "Here's my blog post.",
    "date" : "Sat Dec 12 2009 11:23:21 GMT-0500 (EST)"
    }
  find和findone都可以有查询条件,第4章查询里边会讲。


  • 使用update来更新document
  update函数要有至少两个参数,第一个是条件,第二个是新的document
  先给post变量加一个叫comments的key,给它一个空数组做value。




> post.comments = []
[ ]  执行更新,替换掉title是“My Blog Post”的那个document




> db.blog.update({title : "My Blog Post"}, post)  看看结果




> db.blog.find()
{
"_id" : ObjectId("4b23c3ca7525f35f94b60a2d"),
"title" : "My Blog Post",
"content" : "Here's my blog post.",
"date" : "Sat Dec 12 2009 11:23:21 GMT-0500 (EST)"
"comments" : [ ]
}

  • 使用remove删除document



    > db.blog.remove({title : "My Blog Post"})
    现在这个collection就又空了。
  3.基本数据类型


  • null表示一个空值或者不存在的字段
  • boolean
  • 32位整数
    shell中无法表示,javascript只支持64位浮点小数,所以会被转化为64位浮点小数。
  • 64位整数
    同上
  • 64位浮点小数
  • 字符串
  • symbol
    shell不支持此类型,来自数据库中的symbol类型数据会转化为字符串
  • object id
    0 1 2 3     |4 5 6     |7 8   |9 10 11
    Timestamp|Machine | PID  |Increment
  • date
  • 正则表达式
  • code
  • 二进制数据
  • maximum value
    bson有这样一个专门的类型来表示可能的最大值,shell不支持此类型。
  • minimum value
  • undefined
  • array
  • embeded document

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-83730-1-1.html 上篇帖子: MongoDB数据库文档说明 下篇帖子: MongoDB副本集学习(一):概述和环境搭建
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表