当前位置: 电脑软硬件应用网 > 设计学院 > 网络编程 > 数据库 > 正文 |
|
|||
MySQL使用Amoeba作为Proxy时的注意事项 | |||
2011-8-7 10:16:48 文/纳美人 出处:LUPA开源社区 | |||
与MySQL官方的MySQL Proxy相比,Amoeba配置是很方便的,它基于XML的配置文件,用SQLJEP语法书写规则,比基于lua脚本的MySQL Proxy简单。但它也不是完美无缺的,在实际使用中有很多需要注意的事项。接下来我们就来一一介绍Amoeba的一些注意事项。 Amoeba不支持事务 目前Amoeba不支持事务,任何有关事务的SQL语句都会被Amoeba屏蔽掉。如果必须使用事务,而且事务内的处理操作都可以路由到同一台MySQL上的话,可以考虑在存储过程中使用事务进行处理。另外,Amoeba将来有望支持事务。 Amoeba不支持跨库join和排序 跨库的join和排序非常消耗资源,会导致性能严重下降,Amoeba没有进行支持。 Insert语句必须指定表的列名 Amoeba是根据SQL语句进行解析的,如果SQL语句中没有切分规则中的关键字,那么Amoeba就不会按照规则进行水平切分。比如,按照城市ID进行数据水平切分时,如下语句不会被正确切分: INSERT INTO tb_Shop VALUES (1,5,'店铺的名称','店铺的地址',1,'2011-07-30'); 而如下语句则可以正确切分: INSERT INTO tb_Shop(Shop_ID,ity_ID,ShopName,Address,ShopStatus,CreateTime) VALUES (1,5,'店铺的名称','店铺的地址',1,'2011-07-30'); 也就是说,切分规则中的关键字City_ID必须要在SQL语句中出现。 Amoeba不支持分库分表。 Amoeba不支持分库分表,只能分MySQL实例。 Amoeba不支持大数据量的查询。 大数据量的查询非常消耗内存,Amoeba在进行大数据量查询时性能会非常差。当然,实际业务中需要进行大数据量查询的情况会非常少或者根本没必要实现这种情况。这里所谓的大数据量查询指的是一次查询结果超过十万行。 Amoeba需要更严格的SQL语句规范 From 关键字后面如果不是子查询,一律不能带括号”()”; 如果的表中字段名与关键字或者函数名一样需要带上字符` (比如:mytable.`order`)。 关于Amoeba的一些注意事项的知识就介绍到这里了,希望本次的介绍能够对您有所收获! |
|||
最新热点 | 最新推荐 | 相关阅读 | ||
MySQL常用函数 linux系统下mysql添加用户、删除用户 MYSQL数据库中有NULL值字段的处理 详细讲解MySQL复制 MySQL安装后需要调整什么? MySQL中修改密码及访问限制设置详解 mysql插入数据后提示:数据提供程序 MySQL转换Oracle的七大注意事项 Mysql表别名的用法 如何彻底删除MYSQL? |
关于45IT | About 45IT | 联系方式 | 版权声明 | 网站导航 | |
Copyright © 2003-2011 45IT. All Rights Reserved 浙ICP备09049068号 |