Flex  0.17.9
insert_transaction.h
Go to the documentation of this file.
1 
16 #ifndef GRAPHSCOPE_DATABASE_INSERT_TRANSACTION_H_
17 #define GRAPHSCOPE_DATABASE_INSERT_TRANSACTION_H_
18 
19 #include <limits>
20 
22 #include "flex/utils/allocators.h"
24 #include "grape/serialization/in_archive.h"
25 
26 namespace gs {
27 
28 class MutablePropertyFragment;
29 class WalWriter;
30 class VersionManager;
31 
33  public:
35  WalWriter& logger, VersionManager& vm,
37 
39 
40  bool AddVertex(label_t label, const Any& id, const std::vector<Any>& props);
41 
42  bool AddEdge(label_t src_label, const Any& src, label_t dst_label,
43  const Any& dst, label_t edge_label, const Any& prop);
44 
45  void Commit();
46 
47  void Abort();
48 
49  timestamp_t timestamp() const;
50 
51  static void IngestWal(MutablePropertyFragment& graph, uint32_t timestamp,
52  char* data, size_t length, Allocator& alloc);
53 
54  private:
55  void clear();
56 
58  label_t label, const Any& oid,
59  vid_t& lid);
60 
61  grape::InArchive arc_;
62 
63  std::set<std::pair<label_t, Any>> added_vertices_;
64 
66 
71 };
72 
73 } // namespace gs
74 
75 #endif // GRAPHSCOPE_DATABASE_INSERT_TRANSACTION_H_
gs::InsertTransaction::get_vertex_with_retries
static bool get_vertex_with_retries(MutablePropertyFragment &graph, label_t label, const Any &oid, vid_t &lid)
Definition: insert_transaction.cc:213
gs::InsertTransaction::AddEdge
bool AddEdge(label_t src_label, const Any &src, label_t dst_label, const Any &dst, label_t edge_label, const Any &prop)
Definition: insert_transaction.cc:75
gs::Any
Definition: types.h:383
gs::timestamp_t
uint32_t timestamp_t
Definition: types.h:30
types.h
gs::InsertTransaction::clear
void clear()
Definition: insert_transaction.cc:203
gs::vid_t
uint32_t vid_t
Definition: types.h:31
gs::InsertTransaction
Definition: insert_transaction.h:32
gs::InsertTransaction::added_vertices_
std::set< std::pair< label_t, Any > > added_vertices_
Definition: insert_transaction.h:63
gs::InsertTransaction::timestamp_
timestamp_t timestamp_
Definition: insert_transaction.h:70
gs::InsertTransaction::Commit
void Commit()
Definition: insert_transaction.cc:138
gs::InsertTransaction::arc_
grape::InArchive arc_
Definition: insert_transaction.h:61
gs
Definition: adj_list.h:23
gs::InsertTransaction::IngestWal
static void IngestWal(MutablePropertyFragment &graph, uint32_t timestamp, char *data, size_t length, Allocator &alloc)
Definition: insert_transaction.cc:170
gs::ArenaAllocator
Definition: allocators.h:29
gs::InsertTransaction::timestamp
timestamp_t timestamp() const
Definition: insert_transaction.cc:168
gs::MutablePropertyFragment
Definition: mutable_property_fragment.h:37
gs::WalWriter
Definition: wal.h:50
gs::InsertTransaction::AddVertex
bool AddVertex(label_t label, const Any &id, const std::vector< Any > &props)
Definition: insert_transaction.cc:39
gs::InsertTransaction::InsertTransaction
InsertTransaction(MutablePropertyFragment &graph, Allocator &alloc, WalWriter &logger, VersionManager &vm, timestamp_t timestamp)
Definition: insert_transaction.cc:25
gs::InsertTransaction::alloc_
Allocator & alloc_
Definition: insert_transaction.h:67
allocators.h
gs::VersionManager
Definition: version_manager.h:34
gs::InsertTransaction::logger_
WalWriter & logger_
Definition: insert_transaction.h:68
gs::InsertTransaction::graph_
MutablePropertyFragment & graph_
Definition: insert_transaction.h:65
types.h
gs::InsertTransaction::vm_
VersionManager & vm_
Definition: insert_transaction.h:69
gs::InsertTransaction::Abort
void Abort()
Definition: insert_transaction.cc:160
gs::label_t
uint8_t label_t
Definition: types.h:32
gs::InsertTransaction::~InsertTransaction
~InsertTransaction()
Definition: insert_transaction.cc:37