转自: http://blog.csdn.net/jenminzhang/article/details/9872647 mysql
1.实现基本思路:借助 MySQL的 federated 存储引擎实现 linux
federated 存储引擎简单介绍 :federated 是其中一个专门针对远程数据库的实现。通常状况下在本地数据库中建表会在数据库目录中生成相应的表定义文件,并同时生成相应的数据文件。 但经过federated 引擎建立的表只是在本地有表定义文件,数据文件则存在于远程数据库中
sql
2.查看当前数据库服务是否支持 federated引擎 ,使用命令“ show engines ”命令查看 ,以下图:数据库
"show engines "命令展现结果,简单介绍 :windows
第一列 :名称为 Engine,表示 存储引擎名称 服务器
第二列 :Support,表示当前数据库服务是否支持所对应的存储引擎 ,通常状况 Support有如下几个值:oracle
YES |
支持并开启 |
DEFAULT |
支持并开启 , 而且为默认引擎 |
NO |
不支持 |
DISABLED |
支持,但未开启 |
有上图能够看出,当前数据库服务不支持federated引擎 ,须要手动配置使 当前数据库服务支持federated引擎
3.配置federated数据库存储引擎 :ide
(1)windows 系统配置 :测试
windows下在my.ini中加入federated,从新启动数据库服务便可开启;
url
(2)Linux系统配置:
在my.cnf文件中的mysqld选项中配置 federated ,从新启动数据库服务便可开启;
4.配置数据库远程访问数据:
(1)实用show engines 命令检查数据库是否已经支持federated引擎
(2) 远程数据库表结构
[sql] view plain copy
CREATE TABLE IF NOT EXISTS `isa_ywxx` (
`ywid` int(11) NOT NULL auto_increment COMMENT '主键自动增加',
`ywbh` varchar(10) NOT NULL COMMENT '业务编号',
`ywmc` varchar(20) NOT NULL COMMENT '业务名称',
`ywbz` varchar(30) default NULL COMMENT '备注信息',
PRIMARY KEY (`ywid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='业务信息表' AUTO_INCREMENT=4 ;
--
-- 转存表中的数据 `isa_ywxx`
--
INSERT INTO `isa_ywxx` (`ywid`, `ywbh`, `ywmc`, `ywbz`) VALUES
(1, '01', '综合业务', '综合业务'),
(2, '02', '对公业务', '对公业务'),
(3, '03', 'VIP业务', 'VIP业务');
(3) 给远程数据库服务添加一条数据库登陆用户信息 ,信息以下 :
[sql] view plain copy
grant select on hrkip.isa_ywxx to jenminzhang@'192.85.1.113' identified by 'jenminzhang';
(4) 本地数据库表结构以下 :
[sql] view plain copy
CREATE TABLE IF NOT EXISTS `isa_ywxx` (
`ywid` int(11) NOT NULL auto_increment COMMENT '主键自动增加',
`ywbh` varchar(10) NOT NULL COMMENT '业务编号',
`ywmc` varchar(20) NOT NULL COMMENT '业务名称',
`ywbz` varchar(30) default NULL COMMENT '备注信息',
PRIMARY KEY (`ywid`)
) ENGINE=FEDERATED CHARSET=utf8 CONNECTION='mysql://jenminzhang:jenminzhang@192.85.1.9:3306/hrkip/isa_ywxx';
配置完成了,能够进行测试了 。
5.配置过程当中应注意问题 :
(1)首先要保证数据库服务支持 fedetated存储引擎
(2)本地访问远程数据库配置 :远程服务器中须要添加一个访问数据库表的数据库用户,本地数据库服务中 数据库表结构和远程访问目标数据库表基本一致,只是存储引擎必须为 federated,并须要给其配置connection属性
(3)此例中只是配置本地访问远程数据库的单向配置,若是须要配置双向访问,须要将本地与远程配置兑换,再次配置异常(没有试验,根据以前的OracleDB_link 配置猜想)
备注(参数简单介绍) :
192.85.1.113 :本地数据库服务IP地址
192.85.1.9 :远程数据库没法IP地址
hrkip: 远程数据名称