SwatDB
|
#include <heapfile.h>
Public Member Functions | |
HeapFile (Catalog *catalog, BufferManager *buf_mgr, Schema *schema) | |
Constructor for HeapFile class. | |
~HeapFile () | |
HeapFile destructor. | |
std::uint32_t | getNumPages () |
Returns the number of pages in the file. | |
std::uint32_t | getNumFullPages () |
Returns the number of full pages in the file. | |
std::uint64_t | getNumRecords () |
Returns the number of records in the file. | |
void | createHeader () |
Allocates and initializes the header Page of the file. | |
void | flushHeader () |
Flushes header Page to disk. | |
RecordId | insertRecord (Record record) |
Inserts a Record into the HeapFile. | |
void | getRecord (RecordId record_id, Record *record) |
Sets the record_data of the given Record pointer to the data corresponding to the given RecordId. | |
void | updateRecord (RecordId record_id, Record record) |
Updates the record data in the HeapFile identified by the given RecordId to the data in the provided Record. | |
void | deleteRecord (RecordId record_id) |
Deletes the Record identified by the given RecordId. | |
HeapFileHeader | getHeader () |
THIS METHOD IS FOR DEBUGGING ONLY. Returns the current HeapFileHeader. | |
std::uint64_t | getNumRecs () |
This method returns the number of records in a file. | |
PageId | anonAppend (PageId orig_pid) |
Copies a page and inserts the copy into the begining of the full list. The contents are reset. | |
PageId | atomicAppend (PageId orig_pid) |
Atomic append a page for heapfile. Acquires a mutex, adds page at the beginning of full list, copies data from passed in PageId to the newly created page, then releases mutex. | |
Public Member Functions inherited from RelationFile | |
RelationFile (Catalog *catalog, BufferManager *buf_mgr, Schema *schema) | |
Constructor. Initializes common state associated with every file, including catalog, buf_mgr, and schema. | |
virtual | ~RelationFile () |
Destructor. Data members are cleaned up, but none of the dynamically allocated data members are deleted. The underlying Unix file is not deleted. | |
Schema * | getSchema () |
Returns the schema of the File. | |
Public Member Functions inherited from File | |
File (Catalog *catalog, BufferManager *buf_mgr) | |
Constructor. Initializes common state associated with every file, including catalog, buf_mgr, and schema. | |
virtual | ~File () |
Destructor. Data members are cleaned up, but none of the dynamically allocated data members are deleted. The underlying Unix file is not deleted. | |
FileId | getFileId () |
Returns the FileId of the File. | |
virtual void | printFile () |
Prints out information and/or the contents of the file. Can be overwritten in derived classes. Useful for debugging and testing purposes. | |
PageId | getHeaderId () |
Returns Header PageId. | |
Friends | |
class | Catalog |
class | FileManager |
class | HeapFileScanner |
class | BlockHeapFileScanner |
Additional Inherited Members | |
Protected Member Functions inherited from File | |
void | _setFileId (FileId file_id) |
Sets the file_id and the schema fields of this File. | |
Protected Attributes inherited from RelationFile | |
Schema * | schema |
Protected Attributes inherited from File | |
FileId | file_id |
Catalog * | catalog |
BufferManager * | buf_mgr |
PageId | header_id |
SwatDB HeapFile Class. Represents heap file in the system. It consists of doubly linked list of HeapPage and is an unsorted collection of records. Provides various methods, including inserting, modifying and retrieving records.
HeapFile::HeapFile | ( | Catalog * | catalog, |
BufferManager * | buf_mgr, | ||
Schema * | schema | ||
) |
Constructor for HeapFile class.
catalog | Pointer to the SwatDB Catalog object. |
buf_mgr | Pointer to the SwatDB BufferManager object. |
schema | Pointer to this file's Schema. |
HeapFile::~HeapFile | ( | ) |
Copies a page and inserts the copy into the begining of the full list. The contents are reset.
Page | * corresponding to the page to be copied |
InvalidSchemaHeapFile | If the given Record's Schema does not match that of the HeapFile (compares pointers). |
InsufficientSpaceHeapPage | If the given Record's data exceeds the MAXIMUM_RECORD_SIZE. |
InsufficientSpaceHeapFile | If the number of pages (including the header) in the HeapFile exceeds MAX_PAGE_NUM. |
Atomic append a page for heapfile. Acquires a mutex, adds page at the beginning of full list, copies data from passed in PageId to the newly created page, then releases mutex.
|
virtual |
Allocates and initializes the header Page of the file.
InsufficientSpaceBufMgr | If there is not enough space in the bufferpool. |
Implements File.
|
virtual |
Deletes the Record identified by the given RecordId.
record_id | RecordId identifying the record data to be deleted. |
InvalidSchemaHeapFile | If the given Record's Schema does not match that of the HeapFile(compare pointers). |
InvalidPageIdBufMgr | If the PageNum of the given RecordId is not valid. |
InvalidSlotIdHeapPage | If the SlotId of the given RecordId is not valid. |
Implements RelationFile.
|
virtual |
Flushes header Page to disk.
InsufficientSpaceBufMgr | If there is not enough space in the bufferpool for the header Page. |
InvalidPageIdBufMgr | If the header_id of the File is not valid. |
Implements File.
|
virtual |
Returns the number of pages in the file.
Reimplemented from RelationFile.
|
virtual |
Returns the number of records in the file.
Reimplemented from RelationFile.
Sets the record_data of the given Record pointer to the data corresponding to the given RecordId.
record_id | RecordId of the record_data to be retrieved. |
record | Record pointer to store the retrieved data. |
InvalidSchemaHeapFile | If the given Record pointer's Schema does not match that of the HeapFile (compares pointers). |
InvalidPageIdBufMgr | If the PageNum of the given RecordId is not valid. |
InvalidSlotIdHeapPage | If the SlotId of the given RecordId is not valid. |
Implements RelationFile.
Inserts a Record into the HeapFile.
InvalidSchemaHeapFile | If the given Record's Schema does not match that of the HeapFile (compares pointers). |
InsufficientSpaceHeapPage | If the given Record's data exceeds the MAXIMUM_RECORD_SIZE. |
InsufficientSpaceHeapFile | If the number of pages (including the header) in the HeapFile exceeds MAX_PAGE_NUM. |
Implements RelationFile.
Updates the record data in the HeapFile identified by the given RecordId to the data in the provided Record.
record_id | RecordId identifying the record data to be updated. |
record | Record object containing data to overwrite the record data identified by the given RecordId. |
InvalidSchemaHeapFile | If the given Record's Schema does not match that of the HeapFile (compares pointers). |
InvalidPageIdBufMgr | if the PageNum of the given RecordId is not valid. |
InvalidSlotIdHeapPage | if the SlotId of the given RecordId is not valid. |
InsufficientSpaceHeapPage | if there is not enough space for the updated record in the corresponding HeapPage. |
Implements RelationFile.