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 
23 #include "flex/utils/allocators.h"
25 #include "grape/serialization/in_archive.h"
26 
27 namespace gs {
28 
29 class MutablePropertyFragment;
30 class WalWriter;
31 class VersionManager;
32 
34  public:
36  WalWriter& logger, VersionManager& vm,
38 
40 
41  bool AddVertex(label_t label, const Any& id, const std::vector<Any>& props);
42 
43  bool AddEdge(label_t src_label, const Any& src, label_t dst_label,
44  const Any& dst, label_t edge_label, const Any& prop);
45 
46  void Commit();
47 
48  void Abort();
49 
50  timestamp_t timestamp() const;
51 
52  static void IngestWal(MutablePropertyFragment& graph, uint32_t timestamp,
53  char* data, size_t length, Allocator& alloc);
54 
55  const Schema& schema() const;
56 
57  private:
58  void clear();
59 
61  label_t label, const Any& oid,
62  vid_t& lid);
63 
64  grape::InArchive arc_;
65 
66  std::set<std::pair<label_t, Any>> added_vertices_;
67 
69 
74 };
75 
76 } // namespace gs
77 
78 #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:215
gs::InsertTransaction::schema
const Schema & schema() const
Definition: insert_transaction.cc:211
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:395
gs::timestamp_t
uint32_t timestamp_t
Definition: types.h:30
types.h
schema.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:33
gs::InsertTransaction::added_vertices_
std::set< std::pair< label_t, Any > > added_vertices_
Definition: insert_transaction.h:66
gs::InsertTransaction::timestamp_
timestamp_t timestamp_
Definition: insert_transaction.h:73
gs::InsertTransaction::Commit
void Commit()
Definition: insert_transaction.cc:138
gs::InsertTransaction::arc_
grape::InArchive arc_
Definition: insert_transaction.h:64
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:70
gs::Schema
Definition: schema.h:29
allocators.h
gs::VersionManager
Definition: version_manager.h:34
gs::InsertTransaction::logger_
WalWriter & logger_
Definition: insert_transaction.h:71
gs::InsertTransaction::graph_
MutablePropertyFragment & graph_
Definition: insert_transaction.h:68
types.h
gs::InsertTransaction::vm_
VersionManager & vm_
Definition: insert_transaction.h:72
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