博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用SQL访问MongoDB
阅读量:5875 次
发布时间:2019-06-19

本文共 2515 字,大约阅读时间需要 8 分钟。

使用SQL访问MongoDB

简介

使用SQL访问MongoDB有多种解决方案,就我所知的,除了今天要介绍的MongoDB Connector for BI外,还有Studio 3T,但后者只有在企业版中才提供,使用成本之高是可以想见的,而MongoDB Connector for BI则是MongoDB官方推出的,使用也相当方便。

本文以macOS为例进行说明,使用其他系统的同学也可以参考。

MongoDB Connector for BI的作用如下图所示,它只是做为BI和MongoDB之间的一个代理,将MongoDB的数据转换为关系型的,并不存储数据。

img

MongoDB Connector for BI一共有两个核心组件

  • mongodrdl
  • mongosqld

其实就是两个可执行文件。

mongodrdl

它可以连接MongoDB,并生成一个Document-Relational Definition Language (DRDL) 文件,以便将给定MongoDB集合中的数据转换为关系型的。

mongosqld

作为守护进程运行,响应SQL请求,并将其转换为MongoDB的请求,注意,在启动mongosqld守护进程先,必须先执行mongodrdl生成相应的DRDL文件。

NOTE

本文基本上是官方文档的一个解释,英语好的同学可以直接参考原文:

安装

OpenSSL

使用brew安装OpenSSL

brew updatebrew install openssl

MongoDB

这个不用多说了,安装社区版即可。

MongoDB Connector for BI

同样去官方网站进行下载即可,可以免费使用。

配置

生成DRDL

格式如下

mongodrdl --host {your.mongohost.com} -d dbname [-c collname] -o schema.drdl

NOTE

如果MongoDB启用了密码,则在生成DRDL时,还需要加-u -p --authenticationDatabase这些认证选项,才能生成DRDL。

启动mongosqld

NOTE

对于有认证的MongoDB,需要首先执行以下操作:

  1. 在terminal中执行mysql_config --plugindir查看MySQL的插件所在目录(mysql_config是MySQL安装目录中bin目录下的一个可执行文件)。
  2. 下载C Authentication Plugin——,进入下载页面后选择对应的操作系统进行下载。
  3. 将下载后的文件解压缩,拷贝lib目录下的mongosql_auth.so到MySQL的插件目录中即可,我电脑上的目录是/usr/local/mysql/lib/plugin

官方文档给出的启动方式如下

mongosqld install --config {pathToConfigFile}/mongosqld.confsudo service mongosql start

但在macOS下,使用service mongosqld start的方式显然是无法启动的。

可以使用如下两种方式启动:

使用schema文件

使用mongodrdl生成的DRDL文件,可以直接启动mongosqld

$ mongosqld --schema 

使用config文件

config文件是一种YAML格式的文件,其他配置可以参考官方文档,但schema一定要指定!

如下是我的config文件,假设名称为mongosqld.conf

schema:  path: "/Users/luogang/Dropbox/Development/mongodb/mongodb-bi-x86_64-osx-v2.2.0/bin/candidate.drdl"

使用如下命令启动mongosqld

$ mongosqld --config mongosqld.conf

NOTE

这两种方式启动后,都会监听3307端口,如果你在本机已经启动了MySQL Server,有可能mongosqld无法启动,因为它发现/tmp/mysql.sock已经被使用,这时候可以停止本机的MySQL Server,或者为mongosqld指定新的unix socket(使用--unixSocketPrefix选项)或者不使用UNIX socket(--noUnixSocket选项),但是使用后两种解决方法要注意,MySQL Client连接时,默认会连接/tmp/mysql.sock,由此导致连接的仍然是MySQL Server,而不是mongosqld。

使用MySQL Client连接

向无认证的MongoDB连接

也就是说,要连接的MongoDB没有设置密码,直接连接即可。

$ mysql --protocol tcp --port 3307

向有认证的MongoDB连接

$ mysql '--user=admin?source=admin' --default-auth=mongosql_auth -p

输入密码即可连接成功。

NOTE

这一步输入的用户名--user为MongoDB的用户名,source=指定认证数据库,跟MySQL Server的用户名密码没有一毛钱关系了。

下面这幅图是Mongo Compass中的截图

MySQL Client

下面这幅是在MySQL Client中的截图,可以看出,已经可以使用SQL进行查询了。

MySQL Client

NOTE

使用其他MySQL客户端进行连接的同学,可以在连接页面查看Advanced选项,我在MySQLWorkbench中可以成功连接,在Advanced选项卡中的Others栏填写--user=admin?source=admin --default-auth=mongosql_auth即可。

小结

欢迎大家扫描二维码关注我的微信公众号哦,方便在手机上进行阅读。

我的公众号

转载于:https://www.cnblogs.com/stevenluo/p/7468613.html

你可能感兴趣的文章
汽车常识全面介绍 - 悬挂系统
查看>>
电子政务方向:We7.Cloud政府云门户
查看>>
虚拟机Centos7连接Internet
查看>>
ansible 基本操作(初试)
查看>>
更改tomcat的根目录路径
查看>>
51nod 1292 字符串中的最大值V2(后缀自动机)
查看>>
加快ALTER TABLE 操作速度
查看>>
学习笔记之软考数据库系统工程师教程(第一版)
查看>>
基本网络概念
查看>>
将 ASP.NET Core 2.0 项目升级至 ASP.NET Core 2.1 RC 1
查看>>
js提交图片转换为base64
查看>>
学习CodeIgniter框架之旅(二)继承自定义类
查看>>
Y2161 Hibernate第三次考试 2016年8月18日 试卷分析
查看>>
Angular CLI 使用教程指南参考
查看>>
PHP 程序员的技术成长规划
查看>>
用于守护进程的出错处理函数
查看>>
AppCan可以视为Rexsee的存活版
查看>>
【转】SQL SERVER 2005 数据库状态为“可疑”的解决方法
查看>>
事件、委托、委托方法的总结(使用EventHandler<>)
查看>>
Revit API 创建带箭头的标注
查看>>