打杂
全部博文(524)
分类: Mysql/postgreSQL
2015-10-14 17:04:23
对于本地的数据录表,数据文件是本地的。例如,如果你创建一个名为user的MyISAM表,MyISAM处理器创建一个名为users.MYD的数据文件。对本地表读,插入,删除和更新在本地数据文件里的数据的处理器和记录被以对处理器的特定格式存储。 为了读记录,处理器必须把数据分解进列。为了写记录,列值必须被转换到被处理器使用的行格式并且被写进本地的数据文件。
使用MySQL FEDERATED存储引擎,没有对表的本地数据文件(比如,没有.MYD文件)。取而代之地,一个远程数据库存储那些正常地应该在表中的数据。这使得MySQL客户端API来读,删除,更新和插入数据的使用成为必要。数据取回被通过SELECT * FROM tbl_name SQL语句来初始化。要读这个结果,通过使用mysql_fetch_row() C API函数,行被一次取一个,然后从SELECT结果包中的列转换成FEDERATED处理器期望的格式。
基本流程如下:
1. SQL调用被本地发布
2. MySQL处理器API (数据以处理器格式)
3. MySQL客户端API (数据被转换成SQL调用)
4. 远程数据库-> MySQL客户端API
5. 转换结果包(如果有的话)到处理器格式
6. 处理器 API -> 结果行或受行影响的对本地的计数
四、如何使用FEDERATED表
使用FEDERATED表的步骤是非常简单的。通常,你运行两个服务器,要么在同一个主机上,要么在不同主机上。(一个FEDERATED表使用其它被同一服务器管理的表也是可能的。虽然只有极少的点要这么做)。
首先,你必须在你想要用FEDERATED表访问的远程服务器上有一个表。
接着,在本地服务器上为访问远程表创建一个FEDERATED表:
create table vtiger_greenwork(
id int(10) not null primary key,
type varchar(50) default null,
uploadtime date default null,
name varchar(30) default null,
remark text default null,
userid varchar(30) default null)
ENGINE=FEDERATED connection='mysql://root:password@192.168.1.100:3306/sjcrm/vtiger_greenwork';
(注意: CONNECTION 替代 用在先前版本的MySQL里的COMMENT)。 (注意: CONNECTION 替代 用在先前版本的MySQL里的COMMENT)。
Look:
oh year!
192.168.1.100上sjcrm数据库vtiger_greenwork表中的数据被查出来了。