2021-08-18 22:19:14 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <Parsers/IAST.h>
|
2022-04-19 18:15:27 +00:00
|
|
|
#include <Parsers/ASTQueryWithOnCluster.h>
|
2021-08-18 22:19:14 +00:00
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
using Strings = std::vector<String>;
|
|
|
|
using DatabaseAndTableName = std::pair<String, String>;
|
|
|
|
|
|
|
|
|
|
|
|
/** BACKUP { TABLE [db.]table_name [AS [db.]table_name_in_backup] [PARTITION[S] partition_expr [,...]] |
|
|
|
|
* DICTIONARY [db.]dictionary_name [AS [db.]dictionary_name_in_backup] |
|
2022-05-07 15:14:43 +00:00
|
|
|
* DATABASE database_name [AS database_name_in_backup] [EXCEPT TABLES ...] |
|
2022-01-18 11:45:22 +00:00
|
|
|
* TEMPORARY TABLE table_name [AS table_name_in_backup] |
|
|
|
|
* ALL TEMPORARY TABLES [EXCEPT ...] |
|
|
|
|
* ALL DATABASES [EXCEPT ...] } [,...]
|
2022-04-19 18:15:27 +00:00
|
|
|
* [ON CLUSTER 'cluster_name']
|
2021-11-05 14:18:23 +00:00
|
|
|
* TO { File('path/') |
|
|
|
|
* Disk('disk_name', 'path/')
|
|
|
|
* [SETTINGS base_backup = {File(...) | Disk(...)}]
|
2021-08-18 22:19:14 +00:00
|
|
|
*
|
2022-05-07 15:14:43 +00:00
|
|
|
* RESTORE { TABLE [db.]table_name_in_backup [AS [db.]table_name] [PARTITION[S] partition_expr [,...]] |
|
|
|
|
* DICTIONARY [db.]dictionary_name_in_backup [AS [db.]dictionary_name] |
|
|
|
|
* DATABASE database_name_in_backup [AS database_name] [EXCEPT TABLES ...] |
|
|
|
|
* TEMPORARY TABLE table_name_in_backup [AS table_name] |
|
|
|
|
* ALL TEMPORARY TABLES [EXCEPT ...] |
|
|
|
|
* ALL DATABASES [EXCEPT ...] } [,...]
|
2022-04-19 18:15:27 +00:00
|
|
|
* [ON CLUSTER 'cluster_name']
|
2021-11-05 14:18:23 +00:00
|
|
|
* FROM {File(...) | Disk(...)}
|
2021-08-18 22:19:14 +00:00
|
|
|
*
|
|
|
|
* Notes:
|
|
|
|
* RESTORE doesn't drop any data, it either creates a table or appends an existing table with restored data.
|
|
|
|
* This behaviour can cause data duplication.
|
|
|
|
* If appending isn't possible because the existing table has incompatible format then RESTORE will throw an exception.
|
|
|
|
*
|
2022-05-07 15:14:43 +00:00
|
|
|
* The "AS" clause is useful to backup or restore under another name.
|
2021-08-18 22:19:14 +00:00
|
|
|
* For the BACKUP command this clause allows to set the name which an object will have inside the backup.
|
|
|
|
* And for the RESTORE command this clause allows to set the name which an object will have after RESTORE has finished.
|
|
|
|
*/
|
2022-04-19 18:15:27 +00:00
|
|
|
class ASTBackupQuery : public IAST, public ASTQueryWithOnCluster
|
2021-08-18 22:19:14 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
enum Kind
|
|
|
|
{
|
|
|
|
BACKUP,
|
|
|
|
RESTORE,
|
|
|
|
};
|
|
|
|
Kind kind = Kind::BACKUP;
|
|
|
|
|
|
|
|
enum ElementType
|
|
|
|
{
|
|
|
|
TABLE,
|
|
|
|
DATABASE,
|
|
|
|
ALL_DATABASES,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Element
|
|
|
|
{
|
|
|
|
ElementType type;
|
|
|
|
DatabaseAndTableName name;
|
|
|
|
DatabaseAndTableName new_name;
|
2022-05-07 15:14:43 +00:00
|
|
|
bool is_temp_db = false;
|
2021-08-18 22:19:14 +00:00
|
|
|
ASTs partitions;
|
|
|
|
std::set<String> except_list;
|
2022-04-27 08:35:38 +00:00
|
|
|
|
|
|
|
void setDatabase(const String & new_database);
|
2021-08-18 22:19:14 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
using Elements = std::vector<Element>;
|
2022-04-27 08:35:38 +00:00
|
|
|
static void setDatabase(Elements & elements, const String & new_database);
|
|
|
|
void setDatabase(const String & new_database) { setDatabase(elements, new_database); }
|
|
|
|
|
2021-08-18 22:19:14 +00:00
|
|
|
Elements elements;
|
|
|
|
|
2021-11-05 14:18:23 +00:00
|
|
|
ASTPtr backup_name;
|
|
|
|
|
2022-05-01 13:36:32 +00:00
|
|
|
ASTPtr settings;
|
|
|
|
|
2021-11-05 14:18:23 +00:00
|
|
|
/// Base backup. Only differences made after the base backup will be included in a newly created backup,
|
|
|
|
/// so this setting allows to make an incremental backup.
|
|
|
|
ASTPtr base_backup_name;
|
2021-08-18 22:19:14 +00:00
|
|
|
|
2022-05-01 13:36:32 +00:00
|
|
|
/// List of cluster's hosts' IDs if this is a BACKUP/RESTORE ON CLUSTER command.
|
|
|
|
ASTPtr cluster_host_ids;
|
2021-08-18 22:19:14 +00:00
|
|
|
|
|
|
|
String getID(char) const override;
|
|
|
|
ASTPtr clone() const override;
|
|
|
|
void formatImpl(const FormatSettings & format, FormatState &, FormatStateStacked) const override;
|
2022-04-19 18:15:27 +00:00
|
|
|
ASTPtr getRewrittenASTWithoutOnCluster(const WithoutOnClusterASTRewriteParams &) const override;
|
2021-08-18 22:19:14 +00:00
|
|
|
};
|
|
|
|
}
|