Mongodb相关 (Shell命令 / mongoose)
Mongodb相关
1.创建一个文件夹作为数据库存放的目录
2.打开cmd cd到Mongodb/bin目录去
3.执行mongod --dbpath "第一项创建的文件夹(数据库数据存放目录)"
4.打开新终端,原窗口最小化,运行bin目录下的mongo可执行文件,连接数据库
MongodbShell命令
- use dbName
切换到某个数据库,如果dbname不存在,则会创建并切换
- db.dropDatabase()
删除当前数据库(前提是先进入到当前数据库)
- show dbs
查询所有的数据库
- db.createCollection("tableName")
在当前数据库中创建一张数据表,这个命令不常用
- show collections
查看当前数据库中的所有表(数据集合)
db.tableName.insert();
使用表时如果不存在,会自动创建
- db.tableName.insert({name:'baimao',age:12,sex:'女'})
创建一张表并插入一条数据
- db.tableName.save({name:'baimao',age:12,sex:'女'})
向数据库的某个数据集合插入一条数据
- db.tableName.find({name:'baimao',age:12})
查询name=baimao且age=12的元祖
根据查询条件来查询当前表,并集查询条件用,号
find也可以不写参数,查出全部数据
- db.tableName.find({$or:[{name:'baimao'},{age:18}]});
查询满足name=‘baimao’或者age=18的元祖
- db.tableName.find({age:{$lt:23}})
db.tableName.find({age:{$lte:23}})
db.tableName.find({age:{$gt:23}})
db.tableName.find({age:{$gte:23}})
db.tableName.find({age:{$ne:23}})
查询年龄<(<=,>,>=,!=)23的所有元祖
- 支持正则表达式的查询
查询条件支持正则表达式:
db.people.find({name:/四/}) 查找姓名包含:四 的人
db.people.find({name:/^张/}) 查找姓 张 的人
db.people.find({name:/^张.$/}) 查找姓 张 的人并且不能以空格结束
db.people.count() 集合中数据个数
db.people.find({},{name:1,_id:0}) 只查找name这一列(field)
- db.person.count()
计算当前表的元祖数目
- db.person.find().sort({age:1})
将年龄正序排序
- db.person.find().sort({age:-1})
将年龄逆序排序
- db.person.find().skip(n)
跳过(删除)查询结果中前n条数据。
- db.person.find().limit(n)
从查询结果中取前n条数据。
- db.preson.find().skip(2).limit(3)
从查询结果中取第二条后开始的三条数据
1.插入数据: db.person.insert({"name":"baimao","age":"16"});
2.查找数据: db.person.find();
db.person.find({"name":"baimao"}) ==>可以根据指定查询条件查询
3.更新数据: 整体更新:
db.person.update({"name":"baimao"},{"name":"baimao","age":"15"})
[这种方法在更新字段处写全全部的key和value值]
局部更新:
(1)
var user = db.person.findOne({"name":"baimao"});
user.age = 12;
db.person.update({"name":"baimao"},user);
(2)$inc
db.person.update({"name":"baimao"},{$inc:{"age":30}}); 将baimao的年龄增加30
(3)$set
db.person.update({"name":"baimao"},{$set:{"age":12}}); 将baimao的年龄设置为12
批量更新
db.person.update({"name":"baimao"},{$set:{"age":12}},{mutli:true})
[将所有name为baimao的字段的age属性都设置为12
更新数据(如若没有就增加)
db.person.update({"name":"baimao"},{$set:{"age":12}},{mutli:true},{upsert:true})
[将update的第四个参数设置为true就可实现在查询不到结果的情况下直接增加一条记录]
4.删除数据:
db.person.remove({}); ==> 删除全部
db.person.remove({"name":"baimao"}) 删除指定数据
5.查询:
$gt >
$gte >=
$lt <
$lte <=
$ne !=
无(:) =
无(,) &&
$or || (or指的是在某些键值对中查询)
$in in (in指的是某个key值在一个value值组成的数组中查询)
$nin notIn
正则查询: db.person.find({"name":/^b/,"name":/o$/}) name字段以b开头以o结尾
js方法查询: db.person.find({$where:function() {return this.name == 'baimao'});
Mongodb与Nodejs相关
1.引入Mongodb接口Moogoose
2.node连接数据库(moogoose.connect("mongodb://localhost:27017/data")) data为数据库名称
2.定义模式Schema(模式中定义属性或字段的类型等)模式定义结构
var Schema = moogoose.Schema
var student_Schema = new Schema( {
name:String,
id:Number,
...
},
{
//禁止moogoose创建集合时默认给集合添加versionKey属性
versionKey:false
});
3.根据模式Schema定义模型model 模型操作实例 moogose.model("Student",student_Schema)
4.访问模型 var myStudent = mongoose.model("Student");
或者
var myStudent = mongoose.model("Student",{
name:String,
id:Number,
...
},{
versionKey:false
});
5.创建实例
var student = new myStudent({
name:'baimao',
id:123,
})
归纳:
1.引入mongoose
2.设置mongoose连接并监听on('open'/'error')
3.引用 mongoose自带的Schema
4.通过mongoose自带的Schema设置自定义的Schema(定义表的结构)
5.将自定义的Schema设置在mongoose.model()中 mongoose.model("Comment",Comment_schema); 设置一张表的结构
6.自定义model var MyComment = mongoose.model("Comment"); 创建表
7.创建表的实例 var sam = new MyComment({name:'hhh',age:'jjj'}); 只在save的时候用
mongoose数据的删改查方法通过表来实现 即MyComment来实现 而增加需要表的实例
Mongodb相关 (Shell命令 / mongoose)的更多相关文章
- 统计行数、文件夹个数、文件个数的相关shell命令
极客君最近做项目,刚好遇到需要统计一些sql文件数量的问题,用到一些实用的shell命令,记录下来,以后万一还能用上呢? 如果在终端不打开文件看到一共多少行,则可以使用wc命令来实现: wc -l [ ...
- 测试相关shell命令总结2——结构控制语句,命令行参数
1,shell 中单引号和双引号的区别,单引号不进行解释.双引号进行解释 1,在shell中进行数学运算,放在$和[]中 $[1+2] 有些很奇怪,在.sh文件中放在(())中貌似也能够进行数学运算. ...
- MongoDB 常用shell命令汇总
//指定用户名和密码连接到指定的MongoDB数据库 mongo 192.168.1.200:27017/admin -u user -p password use youDbName 1.Mongo ...
- MongoDB通过JavaDriver执行shell命令,例如创建sharding collection
Mongodb的java driver本身的接口 void createCollection(String collectionName, CreateCollectionOptions create ...
- 快速掌握mongoDB(一)——mongoDB安装部署和常用shell命令
1.mongoDB简介 mongoDB 是由C++语言编写的,是一种分布式的面向文档存储的开源nosql数据库.nosql是Not Only SQL的缩写,是对不同于传统的关系型数据库的数据库管理系统 ...
- mongoDB(一)——mongoDB安装部署和常用shell命令
1.mongoDB简介 mongoDB 是由C++语言编写的,是一种分布式的面向文档存储的开源nosql数据库.nosql是Not Only SQL的缩写,是对不同于传统的关系型数据库的数据库管理系统 ...
- python 之调用Linux shell命令及相关高级应用
最近根据老大要求,将数据进行同步备份,结合第三方提供的工具.第三方服务其实是有python demo的,本想研究下实际的python sdk搞个demo开发的,但是发现有些组建装起来确实头大,而且本公 ...
- 孤荷凌寒自学python第五十六天通过compass客户端和mongodb shell 命令来连接远端MongoDb数据库
孤荷凌寒自学python第五十六天通过compass客户端和mongodb shell 命令来连接远端MongoDb数据库 (完整学习过程屏幕记录视频地址在文末) 今天是学习mongoDB数据库的第二 ...
- Matlab使用新发现1(小技巧:shell 命令、工程工作目录设置相关)
最近在调试一个基于Matlab的程序,在偶然间发现了几个比较有趣的技巧,给大家分享一下(很可能是太菜鸟了,没有涉及这方面,大方之家请勿见笑,对您有所帮助请点赞!) 1. Matlab语言是一种解释型语 ...
随机推荐
- CSS学习笔记05 display属性
HTML标记一般分为块标记和行内标记两种类型,它们也称块元素和行内元素. 块元素 每个块元素通常都会独自占据一整行或多整行,可以对其设置宽度.高度.对齐等属性,常用于网页布局和网页结构的搭建.并且块级 ...
- 【Android Developers Training】 50. 控制相机
注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...
- Spring Boot快速入门
安装 安装依赖 maven是一个依赖管理工具,我们利用maven进行构建.创建一个maven项目,在pom.xml里面添加依赖项 <?xml version="1.0" en ...
- Mac应用推荐
知识管理 Outline Curio Together 开发 Clion Vim + spf13 Transmit 辅助应用 Moom PopClip Timing AppClean Markdown ...
- Spring MVC 项目搭建 -1- 创建项目
Spring MVC 项目搭建 -1- 创建项目 1.创建 Dynamic Web project (SpringDemo),添加相关jar包 2.创建一个简单的controller类 package ...
- ReOut
package JBJADV003;import java.io.*;public class ReOut { /** * @param args */ public static void main ...
- intellij idea 常用快捷键让你事半功倍
为什么谈这个 工欲善其事必先利其器,键盘流是必须的,快捷键首当其冲,请收下!!! 常用快捷键列表 Live Templates 自定义代码模板 取消屏幕的翻转,可以使用ctrl+alt+左右,进行代码 ...
- Java 9 揭秘(9. 打破模块封装)
Tips 做一个终身学习的人. 在此章节中,主要介绍以下内容: 什么是打破模块的封装 如何使用命令行选项将依赖项(添加需要)添加到模块 如何使用--add-exports命令行选项导出模块的未导出包, ...
- Day2_数字类型_字符串类型_列表类型_元组_字典_集合_字符编码_文件处理
数字类型: 作用:年纪,等级,薪资,身份证号等: 10进制转为2进制,利用bin来执行. 10进制转为8进制,利用oct来执行. 10进制转为16进制,利用hex来执行. #整型age=10 prin ...
- English - Green Peanut Butter
There is a guy. He wants to drink 12 cups of green peanut butter. He needs green peanut butter. So h ...