使用Dbeaver 操作 mongodb

文章目录

使用Dbeaver 旗舰版 操作 mongodb

前提

使用前提是得安装dbeaver旗舰版,或者企业版,社区版不支持mongodb连接。

安装破解可以去找我的其他文章(dbeaver-ultimate23.3安装破解)。

使用限制

通过dbeaver工具,仅可执行mongodb的部分脚本,绝大部分脚本都不支持解析执行。

例如,查询mongodb数据库 show dbs,db.test.insertMany()等。还是需要使用mongodb的客户端shell工具来执行。

但是dbeaver可以使用SQL语句去查询mongodb。请看官方解释:

很明确,仅支持部分,上图列表部分。

如果是这个结论,那dbeaver作为操作mongodb的工具,就不是个很好的选择了,唯一比较好的作用,就是数据可视化,及界面化修改删除数据记录。

支持脚本

复制代码
use palces

db.places.find()
# 删除集合(数据表)
db.places.drop()
# 创建集合
db.createCollection('places')

# 批量插入地点数据
db.places.insert( [
   {
      loc: { type: "Point", coordinates: [ 114.537078, 30.505029 ] },
      name: "公寓01",
      category : "Park"
   },
   {
      loc: { type: "Point", coordinates: [ 114.520989, 30.545705 ] },
      name: "公寓02",
      category: "Airport"
   },
   {
      loc: { type: "Point", coordinates: [ 114.554095, 30.483247 ] },
      name: "公寓03",
      category : "Monument"
   }
] )

查询如下:

复制代码
#在loc列创建地理空间索引
db.places.createIndex( { loc : "2dsphere" } )
# 查询距离114.43702,30.492105 点附近50km内的地点,从近到远排
db.places.find( {
   loc: {
      $near: {
         $geometry: {
            type: "Point",
            coordinates: [ 114.43702,30.492105 ]
         },
         $maxDistance : 50000
      }
   }
} )

输出如下

复制代码
# 查询距离114.43702,30.492105 点附件50km内的地点,从近到远排,并返回距离(按球面距离计算)
db.places.aggregate([
   {
     $geoNear: {
        near: { type: "Point", coordinates: [ 114.43702,30.492105 ] },
        distanceField: "dist.calculated",
        maxDistance: 50000,
        includeLocs: "dist.loc",
        spherical: true
     }
   }
])

输出如下:

其中,calculated是计算的距离

经验总结

1 dbeaver 作为一个通用的数据库连接工具,并不能支持数据库所有的shell脚本,例如mongodb的show dbs脚本;

2 若遇到dbeaver 无法执行的脚本,也不必过于纠结,再切换到官方的shell客户端即可;

相关推荐
计算机毕设VX:Fegn089510 分钟前
计算机毕业设计|基于springboot + vue律师咨询系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
冰冰菜的扣jio22 分钟前
入门redis——让你的查询快到起飞
数据库·redis·缓存
drebander24 分钟前
MyBatis-Plus saveBatch 在异步线程中事务未提交问题排查与修复
数据库·mybatis
论迹37 分钟前
【Redis】-- key的过期策略
数据库·redis·缓存
min18112345639 分钟前
产品开发跨职能流程图在线生成工具
人工智能·microsoft·信息可视化·架构·机器人·流程图
weixin199701080161 小时前
废旧物资 item_search - 按关键字搜索商品列表接口对接全攻略:从入门到精通
数据库·python
l1t1 小时前
快速加载CSV文件到数据库的工具pg_csv_loader
数据库·算法
无忧智库1 小时前
深度拆解:某大型医院“十五五”智慧医院建设方案,如何冲刺互联互通五级乙等?(附技术架构与实施路径)
java·数据库·架构
moxiaoran57531 小时前
Java使用Redis ZSet恢复用户能量
数据库·redis·哈希算法
wtsolutions1 小时前
Sheet-to-Doc模板设计最佳实践:创建专业的Word模板
前端·javascript·数据库