3

我有一个关于拆分数据库的问题。这是有问题的查询:

SELECT COUNT(*) FROM monies.link_monies_new lcn '
         . 'INNER JOIN products.link l ON lcn.link_id = l.link_id '
         . 'INNER JOIN products.products_format af ON l.product_format_id = af.product_format_id '
         . 'INNER JOIN products.products_categories ac ON af.product_category_id = ac.product_category_id '
         . 'WHERE lcn.click_time BETWEEN FROM_UNIXTIME(1311721200) AND FROM_UNIXTIME(1311807600) '
         . 'AND ac.product_category_id = 1

问题是现在数据库资金和产品将在不同的服务器上。解决办法是什么?我需要两个查询吗?我有点失落。

谢谢!

4

1 回答 1

4

http://dev.mysql.com/doc/refman/5.0/en/federated-use.html

如果我正确理解了您的问题,您希望在 2 个数据库之间有一个连接表的查询,并且这些数据库将位于不同的服务器上。

假设您在“monies”服务器上运行查询,您将在 monies 服务器上创建指向“products”服务器的联合表。这样,您的查询将继续工作,并且 MySQL 神奇地管理它们位于物理上独立的服务器上的事实。

性能调优可能会有问题,但它是让查询保持当前状态的最简单方法。

例如,您可以在“monies”服务器上创建一个名为“products”的本地数据库;在产品中,您将创建一个“链接”表:

CREATE TABLE link (
    link_id     INT(20) NOT NULL AUTO_INCREMENT,
    ....<<other columns from the link table>>
    PRIMARY KEY  (link_id)
)
ENGINE=FEDERATED

CONNECTION='mysql://fed_user@products_server:9306/products/link';

然后,您可以在不更改任何内容的情况下运行上面的查询。

于 2011-07-29T13:06:26.407 回答