当前位置: 首页 > news >正文

MongoDB数据库操作和程序基础文档

转自:
http://blog.csdn.net/xto/archive/2010/03/22/5403855.aspx


数据库常用操作命令

Bin\mongod run 启动数据库服务端。

bin\mongod.exe --dbpath d:\data\mongo 启动数据库服务端并且将数据库目录设定在该地址下。

run 直接启动。例:./mongod run
--dbpath
指定特定存储目录启动,若目录不存在则创建。例:
./mongod --dbpath /var/data/mongo
--port
指定端口启动。例:./mongod --port 12345

bin\mongon.exe 启动数据库客户端用命令行操作。

停止MONGO服务:
方法1:服务端停止,可使用Ctrl+C
方法2:在客户端停止,可先连接客户端

 ./mongo
 
并使用命令
 db.shutdownerver()
 
然后退出客户端
 exit

 

启动bin\mongodump.exe可以自动备份数据

bin/mongorestore.exe恢复一个mongodump备份数据

bin/mongoexport 导出一个数据表数据为(json,csv)格式

bin/mongoimportjson json格式的数据导入数据表表

bin/mongofiles  gridfs文件操作

注意事项

关闭web服务器操作系统之前必须先备份mongodb,然后关闭mongodb服务,在关闭或者重新启动操作系统。

根据网上资料有人曾说直接关闭操作系统会导致mongodb缓存数据没有被写入硬盘。

要经常性的观察mongodb数据总存储的大小,避免数据过大造成写入困难导致的数据丢失情况。

.Net开发帮助说明

开发类库

MongoDB.Driver0.8.1

该版本仍然处于dbug状态,但好在代码比较简单,因此希望在此基础上构建适合自身操作的驱动层。

数据库连接

Mongo mg = new Mongo(localhost,27087);//声明数据库操作类

 

 

bool result=mg.Connect();//打开连接

Database db = mg.getDB("db");//打开db数据库

IMongoCollection col=db.GetCollection("table");//打开db数据库中的table表

mg.Disconnect();//关闭连接

新增数据

Mongo mg = new Mongo(localhost,27087);//声明数据库操作类

 

 

bool result=mg.Connect();//打开连接

Database db = mg.getDB("db");//打开db数据库

IMongoCollection col=db.GetCollection("table");//打开db数据库中的table表

Document doc = new Document();//声明数据类型

doc["name"] = "xto";//赋值

doc["login"] = "test";//赋值

col.Insert(doc);//插入数据

mg.Disconnect();//关闭连接

 

修改数据

Mongo mg = new Mongo(localhost,27087);//声明数据库操作类

 

 

bool result=mg.Connect();//打开连接

Database db = mg.getDB("db");//打开db数据库

IMongoCollection col=db.GetCollection("table");//打开db数据库中的table表

Document query=new Document();//声明查询条件对象

query.Add("id",1);//查询条件对象赋值

Document newdata = new Document();//声明修改对象

newdata.Add("name","222");//修改对象赋值

col.UpdateAll(newdata,query,true);//更新数据

mg.Disconnect();//关闭连接

简单查询

Mongo mg = new Mongo(localhost,27087);//声明数据库操作类

 

 

bool result=mg.Connect();//打开连接

Database db = mg.getDB("db");//打开db数据库

IMongoCollection col=db.GetCollection("table");//打开db数据库中的table表

Document query=new Document();//声明查询条件对象

query.Add("id",1);//查询条件对象赋值

ICursor cur = col.FindAll();//查询指针

foreach (Document docx in cur.Documents)

{

Response.Write(docx["id"]+"</br>");

}

mg.Disconnect();//关闭连接

分页查询

Mongo mg = new Mongo(localhost,27087);//声明数据库操作类

 

 

bool result=mg.Connect();//打开连接

Database db = mg.getDB("db");//打开db数据库

IMongoCollection col=db.GetCollection("table");//打开db数据库中的table表

Document query = new Document();//声明查询条件对象

Document where = new Document();//声明逻辑条件对象

where.Add("$gt",1);//逻辑条件对象赋值;含义:>1

query.Add("id",where);

ICursor cur = col.Find(query).Skip(10).Limit(100);//从第10条记录开始查询每页显示100条

foreach (Document docx in cur.Documents)

{

Response.Write(docx["id"]+"</br>");

}

mg.Disconnect();//关闭连接

 

复杂查询

Mongo mg = new Mongo(localhost,27087);//声明数据库操作类

 

 

bool result=mg.Connect();//打开连接

Database db = mg.getDB("db");//打开db数据库

IMongoCollection col=db.GetCollection("table");//打开db数据库中的table表

Document query = new Document();//声明查询条件对象

Document where = new Document();//声明逻辑条件对象

where.Add("$gt",1);//逻辑条件对象赋值;含义:>1

query.Add("id",where);

ICursor cur = col.Find(query);

foreach (Document docx in cur.Documents)

{

Response.Write(docx["id"]+"</br>");

}

mg.Disconnect();//关闭连接

 

索引创建

Mongo mg = new Mongo(localhost,27087);//声明数据库操作类

 

 

bool result=mg.Connect();//打开连接

Database db = mg.getDB("db");//打开db数据库

IMongoCollection col=db.GetCollection("table");//打开db数据库中的table表

Document index = new Document();//创建索引对象

index["id"] = 1;//索引对象赋值

col.MetaData.CreateIndex(index,true);//创建索引

mg.Disconnect();//关闭连接

删除数据

Mongo mg = new Mongo(localhost,27087);//声明数据库操作类

 

 

bool result=mg.Connect();//打开连接

Database db = mg.getDB("db");//打开db数据库

IMongoCollection col=db.GetCollection("table");//打开db数据库中的table表

Document query = new Document();//创建删除条件对象

query.Add("id", 1);//条件对象赋值

col.Delete(query,true);//删除满足查询条件的记录

mg.Disconnect();//关闭连接

 

相关文章:

  • Java网络编程与NIO详解11:Tomcat中的Connector源码分析(NIO)
  • C# 正则移除所有的Html标记
  • PHP页面3中跳转方法
  • RTEMS 的小技巧(2011.6.30.)
  • 程序猿爱情表白专用html5动画网页的代码
  • 一次ARP问题的Troubleshooting
  • XMPP添加删除好友
  • SQL Server 2008 Analysis Service第二回
  • Spring Security入门(3-3)Spring Security 手工配置并注入 authenticationProvider 和 异常信息传递...
  • 二十二、二十三天笔记总结
  • How to install nokogiri
  • 微信JS 关闭网页
  • 说说微软MVC中Model用法
  • SICP 习题 (2.11)解题总结:区间乘法的优化
  • Citrix虚拟机磁盘I/O和网络I/O测试工具
  • ----------
  • canvas实际项目操作,包含:线条,圆形,扇形,图片绘制,图片圆角遮罩,矩形,弧形文字...
  • create-react-app做的留言板
  • HTTP中GET与POST的区别 99%的错误认识
  • JavaScript设计模式系列一:工厂模式
  • mysql 5.6 原生Online DDL解析
  • oschina
  • PHP那些事儿
  • ⭐ Unity 开发bug —— 打包后shader失效或者bug (我这里用Shader做两张图片的合并发现了问题)
  • 阿里云爬虫风险管理产品商业化,为云端流量保驾护航
  • 记录:CentOS7.2配置LNMP环境记录
  • 前端工程化(Gulp、Webpack)-webpack
  • 延迟脚本的方式
  • 用jquery写贪吃蛇
  • 源码之下无秘密 ── 做最好的 Netty 源码分析教程
  • 7行Python代码的人脸识别
  • 树莓派用上kodexplorer也能玩成私有网盘
  • ​业务双活的数据切换思路设计(下)
  • #if 1...#endif
  • (4)(4.6) Triducer
  • (C语言)共用体union的用法举例
  • (solr系列:一)使用tomcat部署solr服务
  • (独孤九剑)--文件系统
  • (附源码)springboot炼糖厂地磅全自动控制系统 毕业设计 341357
  • (一)VirtualBox安装增强功能
  • .bat批处理(三):变量声明、设置、拼接、截取
  • .Net CF下精确的计时器
  • .Net Core 中间件验签
  • .NET delegate 委托 、 Event 事件
  • .NET Framework .NET Core与 .NET 的区别
  • .net framework 4.0中如何 输出 form 的name属性。
  • .NET性能优化(文摘)
  • ::前边啥也没有
  • [ C++ ] STL---string类的使用指南
  • [ CTF ] WriteUp- 2022年第三届“网鼎杯”网络安全大赛(朱雀组)
  • [ Linux ] git工具的基本使用(仓库的构建,提交)
  • [ 渗透工具篇 ] 一篇文章让你掌握神奇的shuize -- 信息收集自动化工具
  • [20180129]bash显示path环境变量.txt
  • [2019/05/17]解决springboot测试List接口时JSON传参异常
  • [2021ICPC济南 L] Strange Series (Bell 数 多项式exp)