zoukankan      html  css  js  c++  java
  • Mongodb 利用mongoshell进行数据类型转换

    $type操作符

    检测类型
    种类 代号 别名
    Double 1 “double”
    String 2 “string”
    Object 3 “object”
    Array 4 “array”
    Binary data 5 “binData”
    Undefined 6 “undefined” Deprecated.
    ObjectId 7 “objectId”
    Boolean 8 “bool”
    Date 9 “date”
    Null 10 “null”
    Regular Expression 11 “regex”
    DBPointer 12 “dbPointer”
    JavaScript 13 “javascript”
    Symbol 14 “symbol”
    JavaScript (with scope) 15 “javascriptWithScope”
    32-bit integer 16 “int”
    Timestamp 17 “timestamp”
    64-bit integer 18 “long”
    Min key -1 “minKey”
    Max key 127 “maxKey

    db.article.find({data:{$type:2})    //寻找data字段为string的文档
    

    forEach函数

    对查询结果集合中每个文档使用js函数

    cursor.forEach(function)
    Iterates the cursor to apply a JavaScript function to each document from the cursor.

    使用例子

    data.tagList数组中的string转换为int32,x代表迭代传入的文档

    db.article.find({"data.tagList.0":{$type:2}}).forEach(function(x){
    var i=0;
    var length=x.data.tagList.length; 
    for(i=0;i<length;i++ ){ 
        if(typeof x.data.tagList[i] === 'string') {
            x.data.tagList[i]=NumberInt(x.data.tagList[i]); 
        }  
    };
    db.article.save(x)})
    

    note
    1.使用js新特性要注意,比如我的是不支持for(var a of b)的,还有注意string是小写啊
    2.可以使用print输出

    db.users.find().forEach( function(myDoc) { print( "user: " + myDoc.name ); } );
    
  • 相关阅读:
    【BIEE】清除缓存
    【BIEE】安装好BIEE后,修改默认登录页面不为QuickStart页面
    【BIRT】修改BIRT的背景颜色
    【Oracle】查看死锁与解除死锁
    【Oracle】查看正在运行的存储过程
    【Oracle】表空间相关集合
    【Oracle】Oracle常用语句集合
    MapWindowPoints
    模拟鼠标操作
    SVN MERGE 方法(原创)
  • 原文地址:https://www.cnblogs.com/jcuan/p/5863607.html
Copyright © 2011-2022 走看看