虚位以待(AD)
虚位以待(AD)
首页 > 数据库 > MongoDB数据库 > Mongodb 利用mongoshell进行数据类型转换的实现方法

Mongodb 利用mongoshell进行数据类型转换的实现方法
类别:MongoDB数据库   作者:码皇   来源:互联网   点击:

下面小编就为大家分享一篇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 );
    }
    );

以上这篇Mongodb 利用mongoshell进行数据类型转换就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

  • MongoDB的mongo shell常用操作方法及操作脚本笔记
  • 基于MongoDB数据库的数据类型和$type操作符详解
相关热词搜索: Mongodb mongoshell 数据类型 转换