mongodb批量查询库中表的统计信息

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mongodb批量查询库中表的统计信息相关的知识,希望对你有一定的参考价值。

在mongodb中,查看一个表的统计信息一般用:
db.t.stats()
主要信息有:  
"ns" : "gqtest.t",
"count" : 40001,      ###行数
"size" : 2188945,     ###数据大小单位字节
"storageSize" : 1126400,   
"totalIndexSize" : 1851392,  ###总索引大小
"indexSizes" : {
"_id_" : 753664,
"age_1_name_1" : 1097728
},
"avgObjSize" : 54.72225694357641,
"nindexes" : 2,            ###索引个数

?
提前将获取到的表名写入:college.txt文件。主要是通过正则匹配,可以自己测试,加以调整。

#!/bin/bash
user=admin
passwd=123456
database=gqtest
addres=/opt/mongodb3.2.13/bin/mongo
file=mongo_data.csv
for i in `cat college.txt`
    do
    college_name=`$addres --port 7211 -u$user -p$passwd --authenticationDatabase=admin $database  --eval "db.$i.stats()" |grep ns |awk ‘NR==1{print $3}‘ `
    count=`$addres --port 7211 -u$user -p$passwd --authenticationDatabase=admin $database  --eval "db.$i.stats()" |grep count |awk ‘NR==1{print $3}‘ `
    size=`$addres --port 7211 -u$user -p$passwd --authenticationDatabase=admin $database  --eval "db.$i.stats()" |grep size |awk ‘NR==1{print $3}‘`
    index_num=` $addres --port 7211 -u$user -p$passwd --authenticationDatabase=admin $database  --eval "db.$i.stats()" |grep nindexes |awk ‘NR==1{print $3}‘ `
    indexsize=`$addres --port 7211 -u$user -p$passwd --authenticationDatabase=admin $database --eval "db.$i.stats()" |grep        totalIndexSize |awk ‘NR==1{print $3}‘`
echo -e  "$college_name    $count    $size $index_num $indexsize
" >> $file
done

以上是关于mongodb批量查询库中表的统计信息的主要内容,如果未能解决你的问题,请参考以下文章

javascript 如何获取mongodb查询的统计信息?

Presto统计信息

python脚本统计 MySQL 库中表的个数

详解MongoDB索引优化

kettle-批量同步表数据

MongoDB(课时26 聚合(取的集合个数))