2016-06-07 08:23:15 +00:00
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <DB/TableFunctions/ITableFunction.h>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* remote('address', db, table) - создаёт временный StorageDistributed.
|
|
|
|
|
* Чтобы получить структуру таблицы, делается запрос DESC TABLE на удалённый сервер.
|
|
|
|
|
* Например:
|
2016-06-08 13:08:20 +00:00
|
|
|
|
* SELECT count() FROM remote('example01-01-1', merge, hits) - пойти на example01-01-1, в БД merge, таблицу hits.
|
2016-06-07 08:23:15 +00:00
|
|
|
|
* В качестве имени хоста может быть указано также выражение, генерирующее множество шардов и реплик - см. ниже.
|
|
|
|
|
*/
|
|
|
|
|
class TableFunctionRemote : public ITableFunction
|
|
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
std::string getName() const override { return "remote"; }
|
2016-06-08 13:08:20 +00:00
|
|
|
|
StoragePtr execute(ASTPtr ast_function, Context & context) const override;
|
2016-06-07 08:23:15 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
}
|