广告
返回顶部
首页 > 资讯 > 数据库 >MongoDB中如何使用NoSQL语句
  • 903
分享到

MongoDB中如何使用NoSQL语句

2024-04-02 19:04:59 903人浏览 泡泡鱼
摘要

今天就跟大家聊聊有关mongoDB中如何使用NoSQL语句,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。查看帮忙命令>hlep &n

今天就跟大家聊聊有关mongoDB中如何使用NoSQL语句,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

查看帮忙命令

>hlep  --server级别
>db.help()  --db级别
>db. collectionname .help()   --集合级别

查看所有数据库

>show dbs
--新建的数据库并不在数据库的列集合中,要显示它,我们需要向新建的数据库创建集合。

查看当前数据库

>db

创建数据库

>use DATABASE_NAME

切换到某个数据

>use DATABASE_NAME

删除当前数据库,会把磁盘上的数据库文件一并删除

>db.dropDatabase()

修复数据库

> db.repairDatabase()

拷贝数据库test为test999

> db.copyDatabase('test','test999')

查看所有集合(关系型数据库叫表)

>show collections
>show tables

查看各集合的状态

> db.printCollectionStats()

新建集合

db.createCollection("集合名", {集合的大小属性:大小值,集合的增长属性:增长值,集合的最大容量属性:最大容量值,,,等等})
>db.createCollection("table1")

删除集合table1

>db.table1.drop()

重命名集合table1为table101

>db.table1.renameCollection("table101")

查看集合table1的所在的数据库名称

>db.table1.getDB()

查看集合table1的状态

> db.table1.stats()

查询集合

>db.table1.find() --查询集合的所有数据

>db.table1.findOne() --查询集合的第一条数据

>db.table1.count() --总行数

>db.table1.totalSize() --集合的总大小

>db.table1.storageSize() --集合的储存空间大小

>db.table1.distinct("hid") --只查询列hid,并列出该列的不重复的值

>db.table1.find({"hid":2}) --hid=2

>db.table1.find({"hid":2,"hid2":3}) --hid=2 and hid2=3

>db.table1.find({$or:[{"hid":2},{"hid2":3}]}) --hid=2 or hid2=3

>db.table1.find({"hid":{$gt:1}}) --hid>1

>db.table1.find({"hid":{$gte:1}}) --hid>=1

>db.table1.find({"hid":{$lt:2}}) --hid<2

>db.table1.find({"hid":{$lte:2}}) --hid<=2

>db.table1.find({"hid":/2/}) --hid like '%2%'

>db.table1.find({"hid":/^2/}) --hid like '2%'

>db.table1.find({},{"hid":1,"Go2":1}) --查询指定的两列hid和go2

>db.table1.find({"hid":23},{"hid":1,"go2":1}) --select hid,go2 from table1 where hid=23

>db.table1.find({},{"hid":true,"go2":true})--查询指定的两列hid和go2

>db.table1.find({"hid":23},{"hid":true,"go2":true})--select hid,go2 from table1 where hid=23

>db.table1.find().sort({"hid":1}) --查询结果按hid字段顺序排序

>db.table1.find().sort({"hid":-1}) --查询结果按hid字段降序排序

>db.table1.find().limit(2) --查询前两条数据

>db.table1.find().skip(2) --查询第2条以后的所有数据

>db.table1.find().limit(3).skip(2) --查询第2条以后的后面3条数据

>db.table1.find({"hid":2}).count() --查询hid=2的总行数

插入集合(关系型数据库叫行,mongodb叫文档,insert后不需要手工提交,其他会话可以看到)

方法1

db.collectionname.insert({字段名: "字段值"})

>db.table1.insert({hid:"1"})


方法2

db.集合名.save({字段名: "字段值"})

>db.table1.save({hid:2,hname:"hao2"})

循环插入table1集合

for (var i = 0; i < 30; i++) db.table1.save({hid: "u_" + i, age: 22 + i, sex: i % 2});

更新集合( 关系型数据库叫行,mongodb叫文档 )

>db.table1.update({'hid':2},{$set:{'hid':4}},{multi:true})

把hid字段的值由2修改为4

update默认修改第一条发现的行,multi:true集合示修改多行

删除集合( 关系型数据库叫行,mongodb叫文档 )

>db.table1.remove({'hid2':5}) --删除hid2为5的行

>db.table1.remove({}) --删除所有行

创建索引

创建索引后,数据库目录下会多出一个index-开头的文件

>db.table1.ensureIndex({"hid":1})

>db.table1.ensureIndex({"hid":1,"hid2":-1},{unique:true});

1表示升级排序,-1表示降序排序,"hid":1,"hid2":-1表示组合索引,unique:true表示唯一性索引

查看集合table1的索引信息

>db.table1.getIndexes()

删除集合table1的索引

>db.table1.dropIndexes()

创建用户

>db.createUser({user:"admin",pwd:"admin",roles:[{role:"userAdminAnyDatabase",db:"admin"}]});

>db.createUser({user:"admin1",pwd:"admin1",roles:[{role:"root",db:"admin"}]});

查询用户的三种方法

>use admin  

>show users 

>db.system.users.find()

>db.system.users.find().pretty()

查询当前用户

db.runCommand({connectionStatus:1})

创建replicate的语句,创建replicate前,两个节点启动的时候必须要加上replSet参数,且replSet参数值必须一样,例如为replicate1

>use admin

>config={_id:'replicate1',members:[{_id:0,host:'172.22.1.157:27017'},{_id:1,host:'172.22.1.158:27017'}]}

>rs.initiate(config)

>rs.status(config)

>rs.status()

>show dbs

再到从库执行如下

>rs.slaveOk()

>show dbs

查看replicate复制状态

> db.printReplicationInfo()

查询集合table1的shard版本信

>db.table1.getShardVersion()

查看shard分片信

>db.printShardingStatus()

启动

使用mongod命令,后面接各项参数
mongod -f /mongodb/mongodb.conf

关闭

方法1、

use admin
db.shutdownServer()

方法2、(如果启动用了-f,则关闭的时候也要加-f)

mongod --shutdown

mongod --shutdown -f /mongodb/mongodb.conf

方法3、(不要加-9,否则下次启动会无法启动,需要删除mongod.lock文件或使用mongod启动时必须加上--repair才能启动成功)

kill <mongod process ID>

mongodb切换日志

运行时间长了,mongodb的日志会很大,可以执行切换,生成新的日志,把旧的日志删除,执行这个语句,不影响mongodb服务的运行

> use admin

> db.runCommand({logRotate:1})

执行后,会生成新的名称不变的日志文件,之前的日志会以时间格式命名保存下来

如果是replicate环境,不会影响replicate,primary执行这个语句只切换自己的日志,不影响secondary环境的服务,也不会切换secondary环境的日志;secondary执行这个语句只切换自己的日志,不影响primary环境的服务,也不会切换primary环境的日志

mongodb的日志文件,重启后还在,且会把重启涉及的关闭启动信息追加到这个日志文件中

看完上述内容,你们对MongoDB中如何使用Nosql语句有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网数据库频道,感谢大家的支持。

您可能感兴趣的文档:

--结束END--

本文标题: MongoDB中如何使用NoSQL语句

本文链接: https://www.lsjlt.com/news/56562.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MongoDB中如何使用NoSQL语句
    今天就跟大家聊聊有关MongoDB中如何使用NoSQL语句,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。查看帮忙命令>hlep &n...
    99+
    2022-10-18
  • mongodb dba常用的nosql语句有哪些
    本篇文章给大家分享的是有关mongodb dba常用的nosql语句有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。查看帮忙命令>h...
    99+
    2022-10-18
  • MongoDB DBA常用的NoSQL语句 参考学习
      查看帮忙命令   > hlep  --server级别 > db.help()  --db级别 > db. collectionname . help()   --集合级别     查看所有数据库   >show dbs ...
    99+
    2015-07-22
    MongoDB DBA常用的NoSQL语句 参考学习 数据库入门 数据库基础教程 数据库 mysql
  • 如何使用SQL语句在MongoDB中执行复杂查询?
    如何使用SQL语句在MongoDB中执行复杂查询?摘要:MongoDB是一种流行的NoSQL数据库,其查询语言与关系型数据库SQL语言不同。本文将介绍如何使用SQL语句在MongoDB中执行复杂查询,并提供具体的代码示例。引言:在Mongo...
    99+
    2023-12-17
    MongoDB 复杂查询 SQL语句
  • MongoDB中常用的语句有哪些
    这篇文章给大家分享的是有关MongoDB中常用的语句有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。如果觉得 Mongodb 语句不太好理解,可以和 SQL 语句进行对比,学...
    99+
    2022-10-18
  • mongodb数据如何生成Insert语句
    这篇文章主要介绍mongodb数据如何生成Insert语句,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!执行: db.getCollection('cap.published').find(...
    99+
    2023-06-14
  • MongoDB中的常用语句总结大全
    前言 MongoDB与MySQL基本语句还是有很大区别的,今天再介绍一下MongoDB的一些常用的基本语句,下面话不多说了,来一起看看详细的介绍吧 MOngoDB  删除语句 delete()删...
    99+
    2022-10-18
  • 如何使用SQL语句在MongoDB中进行索引创建和优化?
    如何使用SQL语句在MongoDB中进行索引创建和优化?摘要:在MongoDB中,使用SQL语句进行索引创建和优化是一种高效的方式来提高查询性能。本文将介绍如何使用SQL语句在MongoDB中进行索引的创建和优化,并提供具体的代码示例。引言...
    99+
    2023-12-17
    索引创建:create index 优化查询:query optimization 索引类型:index types
  • 如何在MongoDB中使用SQL语句进行数据备份和恢复?
    如何在MongoDB中使用SQL语句进行数据备份和恢复?摘要:MongoDB是一个非关系型数据库,而SQL是关系型数据库的查询语言。但是,有些时候,我们可能需要使用SQL语句来备份和恢复MongoDB中的数据。本文将介绍如何在MongoDB...
    99+
    2023-12-17
    MongoDB 数据备份 SQL语句
  • c语言中default语句如何使用
    在C语言中,default语句用于switch语句中的默认情况。当没有任何一个case匹配时,会执行default语句块中的代码。 ...
    99+
    2023-10-28
    c语言
  • Linq中如何使用foreach语句
    这篇文章给大家介绍Linq中如何使用foreach语句,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Linq 有很多值得学习的地方,这里我们主要介绍Linq foreach语句,包括介绍foreach循环来强制执行查询...
    99+
    2023-06-17
  • C#中如何使用foreach语句
    C#中如何使用foreach语句,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。C# foreach语句示例说明:要对集合中的内容进行增删改的操作,那么就是要遍历集合,那么C...
    99+
    2023-06-17
  • PHP中如何使用Switch语句
    这篇文章将为大家详细讲解有关PHP中如何使用Switch语句,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。PHP Switch语句工作原理:对表达式(通常是变量)进行一次计算 把表达式的值与...
    99+
    2023-06-17
  • python中for语句如何使用
    在Python中,for语句用于循环迭代一个可迭代对象(如列表、元组、字符串等)中的元素。for循环的基本语法如下:```pytho...
    99+
    2023-09-23
    python
  • java中如何使用sql语句
    在Java中使用SQL语句可以通过以下步骤:1. 导入JDBC相关的包,如`java.sql`和`javax.sql`。2. 加载数...
    99+
    2023-09-27
    java sql
  • sql中如何使用insert语句
    小编给大家分享一下sql中如何使用insert语句,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!SQL的insert语句就是插入...
    99+
    2022-10-18
  • mysql语句中如何使用like
    这篇文章主要介绍了mysql语句中如何使用like,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。mysql语句中like用法:1、搭配【%】使用...
    99+
    2022-10-18
  • SQL中SELECT语句如何使用
    SQL中SELECT语句如何使用,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。  SQL嵌套SELECT语句的用法有哪些  1、单行子...
    99+
    2022-10-18
  • JavaScript中如何使用import语句
    这篇文章主要介绍JavaScript中如何使用import语句,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!JavaScript中有import语句。import语句用于将某个模块中...
    99+
    2022-10-19
  • PostgreSQL中Insert语句如何使用
    PostgreSQL中Insert语句如何使用,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、源码解读standard_pl...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作