Mongodb in Mycat指南
1 前言
Mycat目前支持JDBC连接后端数据库,理论上支持任何数据库,如ORACLE、DB2、SQL Server等,是将其模拟为MySQL,所以对其他数据库只支持标准的SQL语句,而对NoSQL的支持,是封装NoSQL API 基于JDBC的实现。
2 MongoDB in Mycat
Mycat1.3实现了对mongodb的支持。
2.1 配置支持Mongodb
修改conf下的配置schema.xml文件中的以下内容:
配置dataHost
在<dataHost></dataHost>节点下在新增一个mongodb的连接
<dataHost name="jdbchost" maxCon="1000" minCon="1" balance="0" writeType="0" dbType="mongodb" dbDriver="jdbc">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM" url="mongodb://192.168.0.99/" user="admin" password="123456" ></writeHost>
</dataHost>
配置表:
在<schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100">下加上表:
<table name="people" primaryKey="_ID" dataNode="dn4" />
配置dataNode:
在 <dataNode>加上个节点:
<dataNode name="dn4" dataHost="jdbchost" database="test" />
dbDriver一定为jdbc
dbType代表数据库类型,可以为mysql,oracle,mongodb
通过配置这个可以支持其他数据库,
2.1.1 支持oracle的配置如下:
<dataHost name="jdbchost2" maxCon="1000" minCon="1" balance="0" writeType="0" dbType="oracle" dbDriver="jdbc">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM2" url="jdbc:oracle:thin:@192.168.0.99:1521:orcl" user="jifeng" password="jifeng" ></writeHost>
</dataHost>
table,dataNode同mongodb的配置
2.2 支持Mongodb原理
通过实现标准的JDBC接口,调用mongodb api实现对mongodb的操作。
2.2.1 需要的jar
mongo-java-driver-2.11.4.jar
这是mongodb官方提供的支持java的驱动包。
2.2.2 实现原理
通过实现标准的JDBC接口,调用mongodb api实现对mongodb的操作:
(1)解析SQL语句(druid sql parser为SQL解析器)
(2)转化为mongodb api
(3)发送到mongodb服务端实现
2.3 支持的SQL语法
2.3.1 Create table
create table people (name varchar(30),age int,sex int,diqu varchar(20),lev int);
mongodb中不用创建表,也可以使用。
2.3.2 Insert into 插入语句
insert into people (name,age,sex,diqu,lev) values('cs',22,1,'sz',1);
注意在插入数据的时候,必须有字段名,否则会提示错误:
查询下插入的数据:
2.3.3 Update table 更新语句
update people set age =23 where name='mongo';
2.3.4 Select 查询语句
2.3.4.1 支持*的查询
select * from people where name='mongo';
2.3.4.2 支持指定字段名的查询
select name,age from people where name='mongo';
不过会显示mongodb默认的_id字段,下次升级可解决这个问题。
2.3.4.3 where条件
2.3.4.3.1 支持等于:
select name,age from people where name='mongo';
2.3.4.3.2 支持大于:
2.3.4.3.3 支持小于:
2.3.4.3.4 支持小于等于:
2.3.4.3.5 支持大于等于
2.3.4.3.6 支持不等于
2.3.4.3.7 支持AND
支持and表示范围
支持多个and
2.3.4.3.8 支持OR
支持多个or
2.3.4.3.9 支持AND 和OR混合条件
2.3.4.4 排序
支持升降序
多字段排序
2.3.4.5 支持Limit
2.3.5 Delete删除语句
delete from people where name='zz';
2.3.6 Drop语句
drop table people;
删除表
2.4 分片
多个节点的查询出来的数据会自动合并,但目前不支持分页,排序等。
2.5 升级
未来支持聚合运算等。
Mongodb in Mycat指南的更多相关文章
- MongoDB快速入门指南与docker-compose快体验
MongoDB快速入门指南与docker-compose快体验 MongoDB相对于RDBMS的优势 模式少 -MongoDB是一个文档数据库,其中一个集合包含不同的文档.一个文档之间的字段数,内容和 ...
- MongoDB性能优化指南
一.索引 MongoDB 提供了多样性的索引支持,索引信息被保存在system.indexes 中,且默认总是为_id创建索引,它的索引使用基本和MySQL 等关系型数据库一样.其实可以这样说说,索引 ...
- Mongodb实战使用指南
REL_LINK: http://www.mongodb.org.cn/tutorial/9.html 一 启动 启动 mongodb 服务(Mac) $ mongod --config /usr ...
- mongodb节点配置指南
修改复制集节点的优先级 复制集节点的 priority 参数的值决定了选举中该节点的优先级.值越高,优先级越高. 我们可以通过修改复制集配置参数中 members 数组位置的优先级来修改对应机器的优先 ...
- Mongodb在NUMA机器上的优化
10gen在mongodb的部署指南上,提到了在NUMA机器上,mongodb可能会出现问题,参见:http://docs.mongodb.org/manual/administration/prod ...
- [翻译]lithium 快速上手(QuickStart)
快速入门 经典博客教程 很感谢你尝试Li3!这一部分栏目为那些想了解这个框架可以做什么的php用户所设计.像这样深入代码是一种很好的方式去体会快速应用开发(Rapid Application ...
- ELK日志相关
转: Logstash 讲解与实战应用 原创qw871122016-08-20 16:06:07评论(1)40217人阅读 一.Logstash 介绍 Logstash 是一款强大的数据处理工具,它可 ...
- [译] MongoDB Java异步驱动快速指南
导读 mongodb-java-driver是mongodb的Java驱动项目. 本文是对MongoDB-java-driver官方文档 MongoDB Async Driver Quick Tour ...
- 大数据存储:MongoDB实战指南——常见问题解答
锁粒度与并发性能怎么样? 数据库的读写并发性能与锁的粒度息息相关,不管是读操作还是写操作开始运行时,都会请求相应的锁资源,如果请求不到,操作就会被阻塞.读操作请求的是读锁,能够与其它读操作共享,但是当 ...
随机推荐
- Python Web框架要点
1. Web应用程序处理流程 前端客户端(浏览器.APP.ajax.爬虫程序)>>>--http的请求与响应--<<<服务器程序(Gunicorn.uwsig)&l ...
- 网络流最大流dinic的板子
void add(int u,int v,int w){ e[tot].v=v; e[tot].w=w; e[tot].nt=pre[u]; pre[u]=tot++; e[tot].v=u; e[t ...
- 【重构】C# VS 配置引用程序集的路径(分离exe和dll从指定路径调用)
原文:[重构]C# VS 配置引用程序集的路径(分离exe和dll从指定路径调用) 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/CocoWu892 ...
- 安卓手机上安装 谷歌 play 商店
安卓手机上安装 谷歌 play 商店 安卓(Android)就是现在流行的智能手机系统,它是由Google公司和开放手机联盟领导及开发.由于安卓系统的底层代码(AOSP)是开源的,以GPL和Apach ...
- 通俗理解vuex原理---通过vue例子类比
本文主要通过简单的理解来解释下vuex的基本流程,而这也是vuex难点之一. 首先我们先了解下vuex的作用 vuex其实是集中的数据管理仓库,相当于数据库mongoDB,MySQL等,任何组件都可以 ...
- C++访问WebService gSoap方式
一. gSOAP访问WebService 1. 下载gSOAP gSOAP 2.7.17 版下载地址http://sourceforge.net/projects/g ...
- FAILOVER详细步骤
FAILOVER详细步骤 1.Flush主库任何未传输的redo到目标备库 如果primary可以mount,则可以flush任何主库的未传输redo到备库,如果操作成功返回,则可以保证failove ...
- 前端面试题(webpack)
(前端面试题大全,持续更新) webpack3升级到4为什么会提升速度? webpack优化有哪些? webpack的css-loader原理讲一下 webpack压缩js css的方法
- C# 映射
public class Myclass1 { private int m_Count = 100; public string love{get;set;} public int Count { g ...
- HTTP网络协议(四)
确保Web安全的HTTPS HTTP存在三个比较明显的缺点: 通信使用明文(不加密),内容可能会被窃听. 不验证通信方的身份,因此有可能遭遇伪装. 无法证明报文的完整性,所以可能已遭篡改. 尽管HT ...