当前位置: 首页 > article >正文

【绝对无坑】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"
}

http://www.kler.cn/a/507702.html

相关文章:

  • 基于YOLOv8与CGNet的鸟类智能识别系统 深度学习图像分类 鸟类目标检测与分类 图像特征提取 模型优化与应用 数据可视化(源码+指导+定制)
  • 什么是基础镜像
  • Ubuntu 安装和配置 MariaDB
  • 《机器学习》——DBSCAN算法
  • WEB 攻防-通用漏-XSS 跨站脚本攻击-反射型/存储型/DOMBEEF-XSS
  • 1月13日学习
  • 没有正确使用HTTP Range Request,导致访问Azure Blob存储的视频没有实现流式播放
  • AI生成文档——Uni-App CSS 样式开发指南
  • JS宏实例:自创FS对象读取文本文件或CSV文件数据
  • 一、1-2 5G-A通感融合基站产品及开通
  • HarmonyOS NEXT应用开发边学边玩系列:从零实现一影视APP (五、电影详情页的设计实现)
  • CTE与临时表:优劣势对比及使用场景分析
  • 简明docker快速入门并实践方法
  • 代码随想录算法训练营day23(0116)
  • 纯代码实现给WordPress添加文章复制功能
  • C#实现字符串反转的4种方法
  • openharmony/build/README_zh.md学习
  • 查找某个年龄段的用户信息TCP头格式为什么需要 TCP 协议? TCP 工作在哪一层?
  • Spring Boot 条件注解:@ConditionalOnProperty 完全解析
  • 整数的分离与合成
  • DNS介绍(3):应用场景
  • 数据结构之哈希表详解
  • 【Block总结】WTConv,小波变换(Wavelet Transform)来扩展卷积神经网络(CNN)的感受野
  • 【论文阅读笔记】基于YOLO和ResNet深度卷积神经网络的结直肠息肉检测
  • 【SQL】查询前三名
  • STM32 FreeRTOS 任务创建和删除实验(动态方法)