mongodb入门很简单(3)

 ##简单的mongodb入门命令##

1.show dbs;      //查看当前数据库


2.use databaseName;         //选库


3.show tables/collections;           //查看数据库中有哪些表


4.db.help();              //查看一些对database的操作命令


5.mongodb的库是隐式创建的,我们可以use一个不存在的库,然后在改库下创建collection,即可创建库;

例如:db.createCollection(‘user‘);

db.user.insert({id:10, name:‘wangwu‘, age:20});


db.user.find();


6.collection允许隐式创建:


db.collectonName.insert(document);


7.删除collction;


db.collectionName.drop();


8.删除database;


db.dropDatabase(); 

##mongodb基本操作##

1.增:insert

db.stu.insert({stu_id:‘001‘, name:‘xiaoqiang‘});
一次性创建多篇文档:json是一个对象,js中有数组这个概念,我们只需要将多个对象,放到一个数组里就可以了;

例如:
db.stu.insert([{_id:3, sn:‘003‘, name:‘liuqiang‘},{sn:‘006‘, name:‘zhaoming‘}]);
我们可以写的任意深;

2.删:remove

语法:db.collection.remove   (查询表达式,选项);
选项是指:(just_one_line:true/false)    是否只删除一行,默认为false;

例如:
db.stu.remove({sn:‘001‘});             //删除st表中sn为001的学生
db.stu.remove({sn:‘001‘, true});     //只删除一行

注意:
1)查询表达式依然是json对象;
2)查询表达式匹配的行将被删掉;
3)如果不写查询表达式,collection中所有的文档将被删掉;


3.改:update

语法:db.collection.update(查询表达式,赋值表达式,新增选项);
改谁--查询表达式
改成什么样--赋值表达式
操作选项--可选参数

例如:
db.stu.update({name:‘dalang‘}, {name:‘zhagnqiang‘});    //新文档直接替换了旧文档
db.stu.update({name:‘liuwei‘}, {$set:{name:‘yaoming‘}});      //只改某一个列

修改时的赋值表达式:
 $set 修改某列的值
 $unset  删除某个列
 $rename  重命名某个列
 $inc  增长某个列
 $setOnInsert  当upsert为true时,并且发生了insert操作时,可以补充的字段;
 
 exp:
 
 db.stu.insert({name:‘zhangqiang‘,age16,sex:‘m‘,weight:60});
 
 db.stu.update({$set:{name:wangli},$unset:{age:17},$rename:{sex:‘gender‘}, $inc:{weight:2}});


 
可选参数:
  {upsert:false  multi:false}
  upsert:没有匹配的行则直接插入该行(如果有查询到的字段则修改,否则添加新的信息)
  muiti:修改多行(即使查询表达式命中多行,也只改一行,如果想改多行,加入这个选项)
  
exp:

db.stu.update({name:‘zhangqiang‘}, $set:{name:‘lisi‘},{upsert:true});

db.stu.update({name:‘zhangqiang‘}, $set:{name:‘lisi‘,$setOnInsert:{high:180}},{upsert:true});      //加上high属性

db.stu.update({gender:‘m‘},$set:{genter:‘men‘},{multi:true});

4.查:find,findOne

db.stu.find();                       //查询所有的文档

db.stu.find({age:18});          //查询所有文档中age属性的列

db.stu.find({}, {age:20});    //查询所有文档中age=20的列,且不查询id属性

db.stu.find({name:‘zhngsan‘}, {age:1,_id:0});      //查出name是zhangsan 的age都要查出来

时间: 2024-08-03 11:48:35

mongodb入门很简单(3)的相关文章

mongodb入门很简单(2)

mongodb的安装 1.下载mongodb: www.mongodb.org  下载最新的stable版:我下载的版本是3.2.5 2.解压文件 3.不用编译:本身就是编译后的二进制可执行文件 打开我们下载解压好的bin目录如下: bin文件中的内容: bsondump: 导出bson结构mongo: 客户端(相当于mysql.exe)mongod: 服务器(相当于mysqld.exe)mongodump: 整体数据库导出(二进制,相当于mysqldump)mongoimport: 导出易识别

Redis入门很简单之七【使用Jedis实现客户端Sharding】

Redis入门很简单之七[使用Jedis实现客户端Sharding] 博客分类: NoSQL/Redis/MongoDB redisjedisspringsharding分片 <一>. 背景介绍: 1. sharding机制:即通常所说的"分片",允许数据存放在不同的物理机器上,  以适应数据量过大的场景,克服单台机器内存或者磁盘空间的限制.而这种"离散式"地存放,对客户端来说是透明的,对客户端来讲,完全看不到这种差别. 2. 常见的内存缓存中间件,比如

Redis入门很简单之四【初识Jedis】

Redis入门很简单之四[初识Jedis] 博客分类: NoSQL/Redis/MongoDB redisnosql缓存jedis 使用Jedis提供的Java API对Redis进行操作,是Redis官方推崇的方式:并且,使用Jedis提供的对Redis的支持也最为灵活.全面:不足之处,就是编码复杂度较高. [一]. 入门使用: 下载Jedis的依赖包jedis-2.1.0.jar,然后将其添加到classpath下面.然后,即可进行编程:  1. 定义连接:Redis暂时不要设置登录密码 J

Redis入门很简单之五【Jedis和Spring的整合】

Redis入门很简单之五[Jedis和Spring的整合] 博客分类: NoSQL/Redis/MongoDB redisnosql缓存jedisspring 在上一篇文章中,简单介绍了Jedis的连接池使用方式. 如果和Spring进行整合的话,我们将获得更好的简洁性.灵活性,显然是一种更加优雅(graceful)的方式. [一]. 搭建环境: 1. 在之前版本的基础之上,添加如下的依赖:   spring.jar   commons-logging.jar   log4j-1.2.15.ja

Redis入门很简单之二【常见操作命令】

Redis入门很简单之二[常见操作命令] 博客分类: NoSQL/Redis/MongoDB redisnosql缓存 Redis提供了丰富的命令,允许我们连接客户端对其进行直接操作.这里简单介绍一下作为常用的一些命令,包括对字符串.列表.集合.有序集合.哈希表的操作,以及一些其他常用命令. [ 基本操作] 1. 添加记录:通常用于设置字符串(string)类型,或者整数类型:如果key已经存在,则覆盖其对应的值. Shell代码   set name James 2. 获取记录:通过键获取值.

Redis入门很简单之六【Jedis常见操作】

Redis入门很简单之六[Jedis常见操作] 博客分类: NoSQL/Redis/MongoDB redisjedisnosql缓存教程 之前介绍了Jedis的基本操作,连接池的支持,以及和Spring的整合.接下来的内容,继续Jedis的最为常见的操作.主要包括常用的列表(list).集合(set).有序集合(sorted set).哈希表(hash)等数据结构,以及其他特性支持. <一>. 使用list: 可以使用列表模拟队列(queue).堆栈(stack),并且支持双向的操作(L或者

ARM Cortex M0权威指南_PDF电子书下载 带书签目录 高清完整版 http://pan.baidu.com/s/1jGKQSwY MariaDB入门很简单_PDF电子书下载 带

ARM  Cortex  M0权威指南_PDF电子书下载 带书签目录 高清完整版   http://pan.baidu.com/s/1jGKQSwY MariaDB入门很简单_PDF电子书下载 带书签目录 高清完整版  http://pan.baidu.com/s/1hqpgV20 管理就是走流程__没有规范流程,管理一切为零_PDF电子书下载 带书签目录 高清完整版  http://pan.baidu.com/s/1bntuLyf 搜索引擎优化  SEO  方法与技巧  第5版_PDF电子书下

Swift入门很简单

Swift入门很简单 <Swift入门很简单>清华大学出版社,全书共16章,分为3篇. 第 1 篇  介绍了Swift开发环境的搭建.Swift基本应用程序的创建.数据类型.语句.表达式.字符串.集合类型.程序控制结构.函数和闭包等内容: 第 2 篇  介绍了类.继承.枚举类型.结构.构造器.析构方法.扩展和协议等内容: 第 3 篇  介绍了自动引用计数.运算符重载和泛型等内容. 试读下载地址:http://pan.baidu.com/s/1mg0ytVq 随书工具下载地址:http://pa

Arduino入门很简单

Arduino入门很简单 <Arduino入门很简单>全书共16章,分为3篇. 第1篇  Arduino开发基础(第1-4章) 本篇主要内容包括:Arduino概述.电路设计软件Fritzing.Arduino IDE的安装与使用和Arduino编程语言基础.通过本篇的学习,读者可以对Arduino的设计理念.型号,以及设计软件和语言有最基本的掌握.第2篇  Arduino元器件(第5-15章) 本篇主要内容包括:通用元器件介绍.发光二极管LED.蜂鸣器.按钮.电位器.光敏电阻和常见传感器.L