|  | MySQL 8.0.43
    Source Code Documentation | 
Implements the large objects (LOB) module. More...
#include <my_dbug.h>#include "btr0pcur.h"#include "dict0mem.h"#include "page0page.h"#include "row0log.h"#include "univ.i"Go to the source code of this file.
| Classes | |
| struct | lob::ref_mem_t | 
| In memory representation of the LOB reference.  More... | |
| struct | lob::ref_t | 
| The struct 'lob::ref_t' represents an external field reference.  More... | |
| class | lob::BtrContext | 
| The B-tree context under which the LOB operation is done.  More... | |
| struct | lob::InsertContext | 
| The context for a LOB operation.  More... | |
| struct | lob::blob_page_info_t | 
| Information about data stored in one BLOB page.  More... | |
| struct | lob::blob_dir_t | 
| The in-memory blob directory.  More... | |
| struct | lob::ReadContext | 
| The context information for reading a single BLOB.  More... | |
| struct | lob::zReader | 
| Fetch compressed BLOB.  More... | |
| struct | lob::Reader | 
| Fetch uncompressed BLOB.  More... | |
| struct | lob::DeleteContext | 
| The context information when the delete operation on LOB is taking place.  More... | |
| Namespaces | |
| namespace | lob | 
| Provides the large objects (LOB) module. | |
| Typedefs | |
| typedef std::map< page_no_t, buf_block_t * > | BlockCache | 
| Enumerations | |
| enum | lob::opcode { lob::OPCODE_INSERT = 0 , lob::OPCODE_INSERT_UPDATE , lob::OPCODE_UPDATE , lob::OPCODE_INSERT_BULK , lob::OPCODE_UNKNOWN } | 
| LOB operation code for btr_store_big_rec_extern_fields().  More... | |
| Functions | |
| std::ostream & | lob::operator<< (std::ostream &out, const ref_t &obj) | 
| Overload the global output stream operator to easily print the lob::ref_t object into the output stream.  More... | |
| dberr_t | lob::btr_store_big_rec_extern_fields (trx_t *trx, btr_pcur_t *pcur, const upd_t *upd, ulint *offsets, const big_rec_t *big_rec_vec, mtr_t *btr_mtr, opcode op) | 
| Stores the fields in big_rec_vec to the tablespace and puts pointers to them in rec.  More... | |
| byte * | lob::btr_rec_copy_externally_stored_field_func (trx_t *trx, const dict_index_t *index, const rec_t *rec, const ulint *offsets, const page_size_t &page_size, ulint no, ulint *len, size_t *lob_version, bool is_sdi, mem_heap_t *heap, bool is_rebuilt) | 
| Copies an externally stored field of a record to mem heap.  More... | |
| static byte * | lob::btr_rec_copy_externally_stored_field (trx_t *trx, const dict_index_t *index, const rec_t *rec, const ulint *offsets, const page_size_t &page_size, ulint no, ulint *len, size_t *ver, bool is_sdi, mem_heap_t *heap) | 
| ulint | lob::btr_rec_get_field_ref_offs (const dict_index_t *index, const ulint *offsets, ulint n) | 
| Gets the offset of the pointer to the externally stored part of a field.  More... | |
| static const byte * | lob::btr_rec_get_field_ref (const dict_index_t *index, const byte *rec, const ulint *offsets, ulint n) | 
| Gets a pointer to the externally stored part of a field.  More... | |
| static byte * | lob::btr_rec_get_field_ref (const dict_index_t *index, byte *rec, const ulint *offsets, ulint n) | 
| Gets a pointer to the externally stored part of a field.  More... | |
| void | lob::blob_free (dict_index_t *index, buf_block_t *block, bool all, mtr_t *mtr) | 
| Deallocate a buffer block that was reserved for a BLOB part.  More... | |
| std::ostream & | lob::operator<< (std::ostream &out, const blob_page_info_t &obj) | 
| std::ostream & | lob::operator<< (std::ostream &out, const blob_dir_t &obj) | 
| Overloading the global output operator to print the blob_dir_t object into an output stream.  More... | |
| bool | lob::btr_lob_op_is_update (opcode op) | 
| Determine if an operation on off-page columns is an update.  More... | |
| ulint | lob::btr_copy_externally_stored_field_prefix_func (trx_t *trx, const dict_index_t *index, byte *buf, ulint len, const page_size_t &page_size, const byte *data, bool is_sdi, ulint local_len) | 
| Copies the prefix of an externally stored field of a record.  More... | |
| byte * | lob::btr_copy_externally_stored_field_func (trx_t *trx, const dict_index_t *index, ulint *len, size_t *lob_version, const byte *data, const page_size_t &page_size, ulint local_len, bool is_sdi, mem_heap_t *heap) | 
| Copies an externally stored field of a record to mem heap.  More... | |
| static ulint | lob::btr_copy_externally_stored_field_prefix (trx_t *trx, const dict_index_t *index, byte *buf, ulint len, const page_size_t &page_size, const byte *data, bool is_sdi, ulint local_len) | 
| static byte * | lob::btr_copy_externally_stored_field (trx_t *trx, const dict_index_t *index, ulint *len, size_t *ver, const byte *data, const page_size_t &page_size, ulint local_len, bool is_sdi, mem_heap_t *heap) | 
| ulint | lob::btr_rec_get_externally_stored_len (const dict_index_t *index, const rec_t *rec, const ulint *offsets) | 
| Gets the externally stored size of a record, in units of a database page.  More... | |
| void | lob::purge (lob::DeleteContext *ctx, dict_index_t *index, trx_id_t trxid, undo_no_t undo_no, ulint rec_type, const upd_field_t *uf, purge_node_t *node) | 
| Purge an LOB (either of compressed or uncompressed).  More... | |
| dberr_t | lob::update (InsertContext &ctx, trx_t *trx, dict_index_t *index, const upd_t *upd, ulint field_no, ref_t blobref) | 
| Update a portion of the given LOB.  More... | |
| dberr_t | lob::z_update (InsertContext &ctx, trx_t *trx, dict_index_t *index, const upd_t *upd, ulint field_no, ref_t blobref) | 
| Update a portion of the given LOB.  More... | |
| void | lob::print (trx_t *trx, dict_index_t *index, std::ostream &out, ref_t ref, bool fatal) | 
| Print information about the given LOB.  More... | |
| void | lob::z_import (const dict_index_t *index, byte *field_ref, trx_id_t trx_id) | 
| Import the given LOB.  More... | |
| void | lob::import (const dict_index_t *index, byte *field_ref, trx_id_t trx_id) | 
| Import the given LOB.  More... | |
| bool | lob::rec_check_lobref_space_id (dict_index_t *index, const rec_t *rec, const ulint *offsets) | 
| Check if all the LOB references in the given clustered index record has valid space_id in it.  More... | |
| dberr_t | lob::mark_not_partially_updatable (trx_t *trx, dict_index_t *index, const upd_t *update, const mtr_t *btr_mtr) | 
| Mark an LOB that it is not partially updatable anymore.  More... | |
| Variables | |
| const ulint | lob::MAX_SIZE = UINT32_MAX | 
| The maximum size possible for an LOB.  More... | |
| constexpr uint32_t | lob::KB128 = 128 * 1024 | 
| The compressed LOB is stored as a collection of zlib streams.  More... | |
| constexpr uint32_t | lob::Z_CHUNK_SIZE = KB128 | 
| const ulint | lob::BTR_EXTERN_SPACE_ID = 0 | 
| The reference in a field for which data is stored on a different page.  More... | |
| const ulint | lob::BTR_EXTERN_PAGE_NO = 4 | 
| page number where stored  More... | |
| const ulint | lob::BTR_EXTERN_OFFSET = 8 | 
| offset of BLOB header on that page  More... | |
| const ulint | lob::BTR_EXTERN_VERSION = BTR_EXTERN_OFFSET | 
| Version number of LOB (LOB in new format)  More... | |
| const ulint | lob::BTR_EXTERN_LEN = 12 | 
| 8 bytes containing the length of the externally stored part of the LOB.  More... | |
| const ulint | lob::BTR_EXTERN_OWNER_FLAG = 128UL | 
| The most significant bit of BTR_EXTERN_LEN (i.e., the most significant bit of the byte at smallest address) is set to 1 if this field does not 'own' the externally stored field; only the owner field is allowed to free the field in purge!  More... | |
| const ulint | lob::BTR_EXTERN_INHERITED_FLAG = 64UL | 
| If the second most significant bit of BTR_EXTERN_LEN (i.e., the second most significant bit of the byte at smallest address) is 1 then it means that the externally stored field was inherited from an earlier version of the row.  More... | |
| const ulint | lob::BTR_EXTERN_BEING_MODIFIED_FLAG = 32UL | 
| If the 3rd most significant bit of BTR_EXTERN_LEN is 1, then it means that the externally stored field is currently being modified.  More... | |
| const ulint | lob::LOB_HDR_PART_LEN = 0 | 
| The structure of uncompressed LOB page header.  More... | |
| const ulint | lob::LOB_HDR_NEXT_PAGE_NO = 4 | 
| Offset within header of next BLOB part page no.  More... | |
| const ulint | lob::LOB_HDR_SIZE = 8 | 
| Size of an uncompressed LOB page header, in bytes.  More... | |
| const uint | lob::ZLOB_PAGE_DATA = FIL_PAGE_DATA | 
| Start of the data on an LOB page.  More... | |
| const byte | lob::field_ref_almost_zero [FIELD_REF_SIZE] | 
| A BLOB field reference has all the bits set to zero, except the "being
modified" bit.  More... | |
Implements the large objects (LOB) module.
InnoDB supports large objects (LOB). Previously, the LOB was called as externally stored fields. A large object contains a singly linked list of database pages, aka LOB pages. A reference to the first LOB page is stored along with the clustered index record. This reference is called the LOB reference (lob::ref_t). A single clustered index record can have many LOB references. Secondary indexes cannot have LOB references.
There are two types of LOB - compressed and uncompressed.
The main operations implemented for LOB are - INSERT, DELETE and FETCH. To carry out these main operations the following classes are provided.
Inserter - for inserting uncompressed LOB data. zInserter - for inserting compressed LOB data. BaseInserter - a base class containing common state and functions useful for both Inserter and zInserter. Inserter and zInserter derives from this base class. Reader - for reading uncompressed LOB data. zReader - for reading compressed LOB data. Deleter - for deleting both compressed and uncompressed LOB data.
For each main operation, the context information is identified separately. They are as follows:
InsertContext - context information for doing insert of LOB.  DeleteContext - context information for doing delete of LOB. ReadContext - context information for doing fetch of LOB. ` 
| typedef std::map<page_no_t, buf_block_t *> BlockCache |