一、用js写一个模拟用户登录日志表的信息
var userName = "chengxiang"; //声明一个登录名
var timeStamp = Date.parse(new Date()); //声明一个时间戳
var jsonData = {"loginUnser":userName,"loginTime":timeStamp }; //组成json字符串
var db = connect('log'); //链接数据库 链接的是哪一个数据库?
db.login.insert(jsonData); //插入数据 print('[demo]log print success'); //没有错误则显示成功 命令行输入: mongo demo.js 启动服务
此时 通过 show dbs 查询就会发现 多了log这个服务 二、批量插入和循环插入
批量插入比循环插入的速度要快很多,一般工作中我们使用批量插入。 demo如下:
1、循环插入:执行完毕大约需要 1744毫秒
var starTime = (new Date()).getTime(); //得到开始时间
var db = connect('log'); //链接数据库 开始循环
for(var i = 0 ; i<5000; i++){
db.test.insert({'num':i});
} var runTime = (new Date()).getTime()-starTime
print(runTime+"ms,OK") 2、批量插入:执行完毕大约需要 84毫秒
var starTime = (new Date()).getTime(); //得到开始时间
var db = connect('log'); //链接数据库 var tempArray = []
for(var i = 0 ; i<5000; i++){
tempArray.push({'num':i});
}
db.test.insert(tempArray) var runTime = (new Date()).getTime()-starTime
print(runTime+"ms,OK") update命令合集--增删改查
//$set 用来修改一个指定的键值(key) 没有这个值就默认添加
// db.workmateArray.update({"name":"MinJie"},{"$set":{age:23}}) //$set 修改嵌套内容
// db.workmateArray.update({"name":"MinJie"},{"$set":{"skill.SkillThree":'BBQ'}}) //$unset 用于将key删除
// db.workmateArray.update({"name":"MinJie"},{'$unset':{age:''}}) //$inc 对数字进行计算,它是对value值的修改,对字符串不起作用。
// db.workmateArray.update({"name":"MinJie"},{'$inc':{age:-2}}) //multi选项 multi设置为true则全部修改,false默认修改1个
// db.workmateArray.update({},{$set:{interset:[]}},{multi:true}) //upsert选项 在找不到匹配的值的情况加直接添加。比如name:chengxiang 数据库没有,则直动添加
// db.workmateArray.update({"name":"chengxiang"},{$set:{age:23}},{upsert:true}) // $pust 追加数组,追加数组中的值
// db.workmateArray.update({"name":"chengxiang"},{"$set":{interset:['dancing']}})
// db.workmateArray.update({"name":"chengxiang"},{"$push":{interset:'web'}}) // $ne 查找是否存在,如果值不存在则修改,如果值存在就不修改。相当于是没有这个东西我就给你,有就不给你了。
// db.workmateArray.update({"name":"chengxiang",'interset':{"$ne":"web666"}},{"$push":{interset:"web666"}}) // $addToSet 查找值是否存在,不存在就push上去
// db.workmateArray.update({"name":"chengxiang"},{$addToSet:{interset:"web777"}}) // $each 批量追加,一次性追加多个值。先用$addToSet来判断是否存在,然后直接$each直接批量追加
// var bbq = ['a','b','c']
// db.workmateArray.update({'name':"chengxiang"},{$addToSet:{interset:{$each:bbq}}}) // $pop 删除数组的值,只删除一次,参数 1 是从最后面删除,参数 -1 是从最开始删除
// db.workmateArray.update({"name":"chengxiang"},{$pop:{interset:1}}) //数组定位修改 通过索引的方式来修改 数组
// db.workmateArray.update({"name":"chengxiang"},{$set:{"interset.0":'dancing'}})

3、用js文件写mongo命令+update命令的更多相关文章

  1. gulp的使用(二)之gulpfile.js文件的配置

    Gulpfile.js是什么文件: gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器:她不仅能对网站资源进行优化,而且在开发过程中很多重复的任务能够使用正确的工具自动完成:使用她, ...

  2. mongorc.js文件

    当启动的时候,mongo检查用户HOME目录下的一个JavaScript文件.mongorc.js.如果找到,mongo在首次显示提示信息前解析.mongorc.js的内容.如果你使用shell执行一 ...

  3. gulp压缩html,css,js文件流程、监听任务、使用gulp创建服务器、同时运行多个任务、反向代理

    一.初始化 首先先做一个项目初始化,用来记录你项目中用到的工具 再你项目文件下打开一个控制台,输入命令 yarn init -y 进行初始化 输入命令yarn add gulp -g  --- 全局安 ...

  4. Vue中引入静态JS文件(爬坑)

    前言(背景介绍) 开发的项目需要与Threejs的3D项目结合在一起,需要静态引入,jquery.js,stats.js,three.js,ThreeBSP.js等静态文件.开发环境是iview-ad ...

  5. Node.js(window)基础(1)——用cmd命令行访问某一文件夹下的js文件

    一.安装,从官网上下载安装,安装基本一直点击下一步就行.注意:node.js基于Python的,安装node.js之前电脑上要安装Python,最好是Python2.7或2.6. 二.cmd进入命令行 ...

  6. vue引入自己写的js文件

    话不多说,直接上代码呀~ 先来个结构图: 中规中矩的vue-cli就写了一个自己的js文件 那么我想要引入到vue组件里. 1.首先写我的js文件 2.引入到vue组件!!!一定要用{}把方法名拿过来 ...

  7. 自写jquery网页回到顶部效果,渐隐图标,引用js文件就可以

    唔.进来开发需求,当网页内容草鸡多的时候,用户就须要有个button高速回到顶部,而不是自己去滚滑轮~ 原本以为比較难的说,由于上头要求所实用js来实现,哪个页面引用,哪个页面显示. 于是乎,本屌丝就 ...

  8. 如何写一个自定义的js文件

    自定义一个Utils.js文件,在其中写js代码即可.如: (function(w){ function Utils(){} Utils.prototype.getChilds = function( ...

  9. 函数直接写在html页面的<script>里可以调用,但是单独放在js文件里不能调用

    1.函数直接写在页面相当于是你本页调用,所以理所应当可以调用 2.js单独文件不能调用是因为你没有引用js文件,如果引用了的话,也是可以调用的. 引用方式,你可以直接拖拽(我一般都是拖拽,因为路径准确 ...

随机推荐

  1. H_Dp

    <span style="color:#000099;">/* H - 简单dp 例题扩展 Time Limit:3000MS Memory Limit:65536KB ...

  2. Java中对象与引用

    初学Java 时.在非常长一段时间里,总认为基本概念非常模糊. 后来才知道.在很多Java 书中.把对象和对象的引用混为一谈. 假设分不清对象与对象引用,那实在没法非常好地理解以下的面向对象技术.把自 ...

  3. 0x63树的直径与最近公共祖先

    凉 bzoj1999 先把树的直径求出来,从左往右枚举,对于当前位置i,找到满足限制并且最远的点j,当前位置最大值就是max(i~j区间内除直径外的子树路径长度最大值,1~i的长度,j~n的长度) 然 ...

  4. Patterns in the Composite Application Library

    Patterns in the Composite Application Library Inversion of Control https://www.codeproject.com/Artic ...

  5. 微阅读,不依赖playground,打包成H5版本--案例学习

    微阅读,不依赖playground,打包成H5版本 https://github.com/vczero/weex-yy-h5

  6. vue插件 vue-seamless-scroll 无缝滚动插件ES6使用总结

    最近因为需求需要写一个项目信息无缝向上滚动组件,在网上搜了一下,看到大家的一致好评就果断的使用了vue-seamless-scroll组件.下面就简单的介绍它的使用,具体详细的使用推荐大家去看下开发者 ...

  7. pythonOCC版 瓶子代码

    #!/usr/bin/env python # -*- coding:utf-8 -*- ##Copyright 2009-2015 Thomas Paviot (tpaviot@gmail.com) ...

  8. Python金融量化

    Python股票数据分析 最近在学习基于python的股票数据分析,其中主要用到了tushare和seaborn.tushare是一款财经类数据接口包,国内的股票数据还是比较全的 官网地址:http: ...

  9. caffe 参数介绍 solver.prototxt

    转载自 http://blog.csdn.net/cyh_24/article/details/51537709 solver.prototxt net: "models/bvlc_alex ...

  10. 状态模式(state)C++实现

    状态模式 当一个对象的内在状态改变时允许改变其行为,这个对象看起来像是改变了其类. 状态模式主要解决的是当控制一个对象状态转换的条件表达式过于复杂时的情况.把状态的判断逻辑转移到表示不同状态的一系列类 ...