一、数据库使用

  1.使用mongodb服务,必须先开启服务,开启服务使用 mongod --dbpath D:mongdb    (D:mongdb  自己所创建数据库的路径, 在cmd窗口中输入)

2.管理mongodb数据库,mongo (必须新建一个新的cmd窗口输入,之前打开的cmd窗口不能关闭)

**  cls  清屏命令

二、创建数据库

1.使用数据库、创建数据库

use student    如果真的想把这个数据库创建成功,那么必须插入一个数据  数据库中不能直接插入数据,只能往集合(collections)中插入数据,不需要专门创建集合,只需要写点语法插入数据就会创建集合

db.student.insert({"name":"xiaoming"}); //插入数据

 show collections  就能看到刚才创建的集合(student)

2.删除当前所在的数据库

db.dropDatabase();

删除集合语法  db.collection_name.drop

db.student.drop()

三、插入数据

db.student.insert({"name":"xiaoming"}); //插入数据

四、查找数据

 1.查询所有记录

db.student.find()

2.查询去掉后的当前聚集集合中的某列的重复数据

db.student.disnct("name")              //会过滤掉相同的数据,只显示一条

3.查询age="25"的记录

db.sutdent.find({"age":"25"})     //只查询出一条数据

4.查询age>22的记录

db.student.find({age:{$gt:22}})

5.查询age<22的记录

db.student.find({age:{$lt:22}})

6.查询age>=25的记录

db.student.find({"age":{$gte:25}})

7.查询age<=25的记录

db.student.find({"age":{$lte:25}})

8.查询age>=23 并且age<=26

db.student.find({age:{$gte:23,$lte:26}})

9.查询name中包含moongo的数据    模糊查询用于搜索

db.student.find({name:/mongo/})

10.查询name中以mongo开头的

db.student.find({name:/^mongo/})

11.查询指定列name、age数据

db.sutdent.find({},{name:1.age:1})

12.查询指定列name、age数据,age>25

db.student.fiind({age:{$gt:25}},{name:1,age:1})

13.按照年龄排序   1升序   -1降序

db.student.find().sort({age:1})    按年龄升序排序

db.studnet.find().sort({age:-1})   按年龄降序排序

14.查询name=zhangsan,age=22的数据

db.student.find({'name':'zhangsan','age':'22'})

15.查询前5条数据

db.student.find().limit(5)

16.查询10条以后的数据

db.student.find().skip(10);

17.查询在5-10条之间的数据

db.student.find().limit(10).skip(5);   //可用于分页 ,limit是pageSize,skip是第几页 *(乘以)pageSize

18. or与查询

db.student.find({$or:[{age:22},{age:25}]})   查询age22或者25的数据

19.查询第一条数据  findOne

db.student.findOne()

20.查询某个结果集的记录条数

db.student.find({age:{$gte:25}}).count()    查询age大于25的数据

如果要返回限制之后的记录数量,要使用 count(true)或者 count(非 0) db.users.find().skip(10).limit(5).count(true);

四、修改数据

1.db.student.update({"name":"小明"},{$set:{"age":16}});              查找名字叫做小明的,把年龄更改为 16 岁:

2. db.student.update({"score.shuxue":70},{$set:{"age":33}});    查找数学成绩是 70,把年龄更改为 33 岁:

3. db.student.update({"sex":"男"},{$set:{"age":33}},{multi: true});    更改所有匹配项目:"

4. db.student.update({"name":"小明"},{"name":"大明","age":16});  完整替换,不出现$set 关键字了

5.db.users.update({name: 'Lisi'}, {$inc: {age: 50}}, false, true); 相当于:update users set age = age + 50 where name = ‘Lisi’;

6.db.users.update({name: 'Lisi'}, {$inc: {age: 50}, $set: {name: 'hoho'}}, false, true); 相当于:update users set age = age + 50, name = ‘hoho’ where name = ‘Lisi’;

五、删除数据

db.collectionsNames.remove( { "borough": "Manhattan" } )     删除集合

db.users.remove({age: 132});

mongdb数据库的操作的更多相关文章

  1. Linux 下Mongdb数据库

    一.安装mongdb 1.创建安装目录 # mkdir /data/local # mkdir /data/local/mongodbdata 2.解压安装包 # tar -xvf /software ...

  2. python代理池的构建4——mongdb数据库的增删改查

    上一篇博客地址:python代理池的构建3--爬取代理ip 一.mongdb数据库的增删改查(Mongo_pool.py) #-*-coding:utf-8-*- ''' 实现代理池的数据库模块 ●作 ...

  3. php模拟数据库常用操作效果

    test.php <?php header("Content-type:text/html;charset='utf8'"); error_reporting(E_ALL); ...

  4. Android-Sqlite数据库的操作

    Sqlite数据库的简单操作: 设置增删改查的按钮,xml界面布局设置 <?xml version="1.0" encoding="utf-8"?> ...

  5. (四)SQL入门 数据库的操作与事务管理

    数据库的操作,有三个最基本的语句,insert插入,update修改,delete删除. 不同的数据库厂商的实现可能不同,所以就不说具体的语法怎么写的了.说语法也没有意义,到处都可以复制粘贴,记得听某 ...

  6. Laravel框架数据库CURD操作、连贯操作使用方法

    Laravel框架数据库CURD操作.连贯如何来操作了这个操作性是非常的方便简单了我们在这里来为各位介绍一篇相关的教程,具体的细节步骤如下文介绍.   Laravel是一套简洁.优雅的PHP Web开 ...

  7. zabbix数据库mariadb从服务器迁移到云mysql数据库的操作

    zabbix数据库mariadb从本机迁移到云mysql数据库的操作 1.将zabbix数据库导出,并导入到云数据库中 由于数据库较大,如果直接使用shell会话中断会导致数据库导出或者导入失败,使用 ...

  8. 使用my exclipse对数据库进行操作(4)

    四.删除 public class class4 { public static void main(String[] args) { // TODO Auto-generated method st ...

  9. 从C#到Objective-C,循序渐进学习苹果开发(7)--使用FMDB对Sqlite数据库进行操作

    本随笔系列主要介绍从一个Windows平台从事C#开发到Mac平台苹果开发的一系列感想和体验历程,本系列文章是在起步阶段逐步积累的,希望带给大家更好,更真实的转换历程体验.本篇主要开始介绍基于XCod ...

随机推荐

  1. 斯坦福CS231n—深度学习与计算机视觉----学习笔记 课时26&&27

    课时26 图像分割与注意力模型(上) 语义分割:我们有输入图像和固定的几个图像分类,任务是我们想要输入一个图像,然后我们要标记每个像素所属的标签为固定数据类中的一个 使用卷积神经,网络为每个小区块进行 ...

  2. HDU5145:5145 ( NPY and girls ) (莫队算法+排列组合+逆元)

    传送门 题意 给出n个数,m次访问,每次询问[L,R]的数有多少种排列 分析 \(n,m<=30000\),我们采用莫队算法,关键在于区间如何\(O(1)\)转移,由排列组合知识得到,如果加入一 ...

  3. POJ2365【几何】

    因为给出的点已经是顺时针了, 整个长度=相邻点距离+一个圆周长: C++ac代码-G++wa-因为标准不一样.G++用f //#include <bits/stdc++.h> #inclu ...

  4. bzoj 1396: 识别子串【SAM+线段树】

    建个SAM,符合要求的串显然是|right|==1的节点多代表的串,设si[i]为right集合大小,p[i]为right最大的r点,这些都可以建出SAM后再parent树上求得 然后对弈si[i]= ...

  5. poj 2492 A Bug's Life【带权并查集】

    就是给一个无向图判是否有奇环 用带权并查集来做,边权1表示连接的两个节点异性,否则同性,在%2意义下进行加法运算即可,最后判相同的时候也要%2,因为可能有负数 #include<iostream ...

  6. bzoj4145 [AMPPZ2014]The Prices(状压dp)

    Description 你要购买m种物品各一件,一共有n家商店,你到第i家商店的路费为d[i],在第i家商店购买第j种物品的费用为c[i][j], 求最小总费用. Input 第一行包含两个正整数n, ...

  7. scrapy将爬取到的数据存入elasticsearch

    pip安装 elasticsearch-dsl的包, 是elasticsearch提供给python 的接口 if __name__ == "__main__": 这个用来调试,还 ...

  8. 51Nod 1092 回文字符串

    最开始毫无头绪,然后参照了一位dalao的博客,思路是一个正序的字符串将其逆序,然后求最长公共子序列(LCS),emm也属于动态规划. #include <iostream> #inclu ...

  9. SpringMVC + ajax

    1.ajax 返回汉字乱码 解决方法: http://blog.sina.com.cn/s/blog_5f39177b0101it7h.html //方案一 response.setCharacter ...

  10. websocket来回收发消息

    # server- # pip install geventwebsocket# pip install flask from flask import Flask, render_template, ...