【绝对无坑】Mongodb获取集合的字段以及数据类型信息

Mongodb获取集合的字段以及数据类型信息

感觉很LOW的一个数据仓工具seatunel,竟然不能自动读取mongodb的表结构信息,需要手工创建。

然鹅,本人对mongodb也是新手,很多操作也不知所措,作为一个DBA,始终还是被研发的甩锅,没得办法只能想办法帮忙把集合的字段类型导出来给他。

网上找了很多方法都不行,坑太多了。

原本想使用mongodump工具导出,但是由于版本限制,mongodb4.4版本才支持schemaonly参数,本人服务器的版本是4.2

在此,为了方便需要的小伙伴,就此贴出无坑版操作代码,希望有所帮助:

复制代码
winrs:PRIMARY> use testdb;
switched to db testdb
winrs:PRIMARY> var collection = db.dbaList;
winrs:PRIMARY> var fields = {};
winrs:PRIMARY> collection.find().forEach(function(doc) {
...     for (var key in doc) {
...         if (!fields[key]) {
...             fields[key] = typeof doc[key];
...         }
...     }
... });
winrs:PRIMARY> printjson(fields);
{
        "_id" : "number",
        "n" : "string",
        "brand" : "string",
        "stand" : "string",
        "group" : "string",
        "area" : "string",
        "dept" : "string",
        "ip" : "string",
        "port" : "number",
        "sta" : "number",
        "c_sta" : "number",
        "e_flag" : "number",
        "u_t" : "string",
        "w_t" : "string",
        "sta_t" : "string",
        "c_sta_t" : "string",
        "stop_t" : "string",
        "power" : "number",
        "v" : "number",
        "s" : "number",
        "h" : "number",
        "b_a" : "number",
        "w_a" : "number",
        "h_a" : "number",
        "l" : "number",
        "e_c" : "object",
        "m_c" : "object",
        "o_c" : "object",
        "timer" : "number",
        "count" : "number",
        "e_send" : "number",
        "m_sta" : "number",
        "s_sta" : "number",
        "sta_his_id" : "string",
        "alert_his_id" : "object",
        "c_sta_his_id" : "string",
        "alert_time" : "object",
        "ensure" : "number",
        "update_time" : "string",
        "fmis_id" : "string",
        "remarks" : "string",
        "ensure_time" : "string",
        "user_id" : "string"
}
相关推荐
舒一笑13 小时前
程序员效率神器:一文掌握 tmux(服务器开发必备工具)
运维·后端·程序员
IvorySQL15 小时前
PostgreSQL 技术日报 (3月6日)|为什么 Ctrl-C 在 psql 里让人不安?
数据库·postgresql·开源
NineData16 小时前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
IvorySQL21 小时前
PostgreSQL 技术日报 (3月5日)|规划器控制力升级,内核能力再进阶
数据库·postgresql·开源
数据组小组1 天前
免费数据库管理工具深度横评:NineData 社区版、Bytebase 社区版、Archery,2026 年开发者该选哪个?
数据库·测试·数据库管理工具·数据复制·迁移工具·ninedata社区版·naivicat平替
梦想很大很大2 天前
拒绝“盲猜式”调优:在 Go Gin 项目中落地 OpenTelemetry 链路追踪
运维·后端·go
Sinclair2 天前
内网服务器离线安装 Nginx+PHP+MySQL 的方法
运维
叶落阁主2 天前
Tailscale 完全指南:从入门到私有 DERP 部署
运维·安全·远程工作
悟空聊架构2 天前
基于KaiwuDB在游乐场“刷卡+投币”双模消费系统中的落地实践
数据库·后端·架构