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