OmniSciDB  c1a53651b2
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Parser::DumpTableStmt Class Reference

#include <ParserNode.h>

+ Inheritance diagram for Parser::DumpTableStmt:
+ Collaboration diagram for Parser::DumpTableStmt:

Public Member Functions

 DumpTableStmt (const rapidjson::Value &payload)
void execute (const Catalog_Namespace::SessionInfo &session, bool read_only_mode) override
- Public Member Functions inherited from Parser::DumpRestoreTableStmtBase
 DumpRestoreTableStmtBase (const rapidjson::Value &payload, const bool is_restore)
CompressionType defaultCompression (bool is_restore)
CompressionType validateCompression (const std::string &compression, const bool is_restore)
std::string tarCompressionStr (CompressionType compression, const bool is_restore)
const std::string * getTable () const
const std::string * getPath () const
const CompressionType getCompression () const
- Public Member Functions inherited from Parser::DDLStmt
void setColumnDescriptor (ColumnDescriptor &cd, const ColumnDef *coldef)
- Public Member Functions inherited from Parser::Node
virtual ~Node ()

Additional Inherited Members

- Public Types inherited from Parser::DumpRestoreTableStmtBase
enum  CompressionType { CompressionType::kGZIP, CompressionType::kLZ4, CompressionType::kNONE }
- Protected Attributes inherited from Parser::DumpRestoreTableStmtBase
std::unique_ptr< std::string > table_
std::unique_ptr< std::string > path_
CompressionType compression_
TableArchiverS3Options s3_options_

Detailed Description

Definition at line 1451 of file ParserNode.h.

Constructor & Destructor Documentation

Parser::DumpTableStmt::DumpTableStmt ( const rapidjson::Value &  payload)

Definition at line 6904 of file ParserNode.cpp.

6905  : DumpRestoreTableStmtBase(payload, false) {}
DumpRestoreTableStmtBase(const rapidjson::Value &payload, const bool is_restore)

Member Function Documentation

void Parser::DumpTableStmt::execute ( const Catalog_Namespace::SessionInfo session,
bool  read_only_mode 

Implements Parser::DDLStmt.

Definition at line 6907 of file ParserNode.cpp.

References Catalog_Namespace::SessionInfo::checkDBAccessPrivileges(), Parser::DumpRestoreTableStmtBase::compression_, AccessPrivileges::CREATE_TABLE, TableArchiver::dumpTable(), legacylockmgr::ExecutorOuterLock, Catalog_Namespace::SessionInfo::getCatalog(), legacylockmgr::LockMgr< MutexType, KeyType >::getMutex(), lockmgr::TableLockMgrImpl< TableSchemaLockMgr >::getReadLockForTable(), Parser::DumpRestoreTableStmtBase::path_, AccessPrivileges::SELECT_FROM_TABLE, Parser::DumpRestoreTableStmtBase::table_, TableDBObjectType, and Parser::DumpRestoreTableStmtBase::tarCompressionStr().

Referenced by heavydb.cursor.Cursor::executemany().

6908  {
6909  // valid in read_only_mode
6910  const auto execute_read_lock =
6915  auto& catalog = session.getCatalog();
6916  // Prevent modification of the table schema during a dump operation, while allowing
6917  // concurrent inserts.
6918  auto table_read_lock =
6921  // check access privileges
6924  *table_)) {
6925  throw std::runtime_error("Table " + *table_ +
6926  " will not be dumped. User has no select privileges.");
6927  }
6930  throw std::runtime_error("Table " + *table_ +
6931  " will not be dumped. User has no create privileges.");
6932  }
6933  const TableDescriptor* td = catalog.getMetadataForTable(*table_);
6934  TableArchiver table_archiver(&catalog);
6935  table_archiver.dumpTable(td, *path_, tarCompressionStr(compression_, false));
6936 }
static std::shared_ptr< WrapperType< MutexType > > getMutex(const LockType lockType, const KeyType &key)
std::string tarCompressionStr(CompressionType compression, const bool is_restore)
static const AccessPrivileges SELECT_FROM_TABLE
Definition: DBObject.h:160
std::shared_lock< T > shared_lock
std::unique_ptr< std::string > table_
Definition: ParserNode.h:1445
static const AccessPrivileges CREATE_TABLE
Definition: DBObject.h:158
std::unique_ptr< std::string > path_
Definition: ParserNode.h:1446
Catalog & getCatalog() const
Definition: SessionInfo.h:75
static ReadLock getReadLockForTable(Catalog_Namespace::Catalog &cat, const std::string &table_name)
Definition: LockMgrImpl.h:238
bool checkDBAccessPrivileges(const DBObjectType &permissionType, const AccessPrivileges &privs, const std::string &objectName="") const
Definition: SessionInfo.cpp:24

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

The documentation for this class was generated from the following files: