好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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

?

1

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

forEach函数

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

?

1

2

cursor.forEach(function)

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

使用例子

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

?

1

2

3

4

5

6

7

8

9

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输出

?

1

db.users.find().forEach( function(myDoc) { print( "user: " + myDoc.name ); } );

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

原文链接:https://HdhCmsTestcnblogs测试数据/jcuan/p/5863607.html

查看更多关于Mongodb 利用mongoshell进行数据类型转换的实现方法的详细内容...

  阅读:28次