OpenDBX::Lob(3) | opendbx | OpenDBX::Lob(3) |
NAME¶
OpenDBX::Lob - Handling large objects if supported by the database.
SYNOPSIS¶
Public Member Functions¶
void close () throw ( std::exception )
Closes the large object and commits the changes. Lob (const Lob
&ref) throw ()
Copy constructor. Lob & operator= (const Lob
&ref) throw ()
Assign large object instance to another one. ssize_t read (void
*buffer, size_t buflen) throw ( std::exception )
Reads content from large object into the buffer. ssize_t write (void
*buffer, size_t buflen) throw ( std::exception )
Writes data from the buffer into the large object. ~Lob () throw ()
Destroy large object instance if no other references exist.
Protected Member Functions¶
Lob () throw ()
Default constructor. Lob (Lob_Iface *impl) throw ( std::exception )
Create large object instance.
Detailed Description¶
Handling large objects if supported by the database.
Author
Version
Constructor & Destructor Documentation¶
OpenDBX::Lob::Lob () [inline], [protected]¶
Default constructor. The default constructor isn't part of the public interface as the object must not be created manually. Instead, the Result::getLob() method is a factory for instances of the large object class.
Returns
OpenDBX::Lob::Lob (Lob_Iface * impl)std::exception [protected]¶
Create large object instance. The constructor isn't part of the public interface as the object must not be created manually. Instead, the Result::getLob() method is a factory for instances of the large object class.
Parameters
Returns
Exceptions
OpenDBX::Lob::~Lob ()¶
Destroy large object instance if no other references exist. Each large object uses a reference counter to remember if the internal variables are shared with other objects. If this isn't the case or if this object is the last one referencing the variables, the object is cleanup up and the allocated memory freed.
OpenDBX::Lob::Lob (const Lob & ref)¶
Copy constructor. Enables the transfer of the internal state of an object ref of the same type to this object. Both objects share the same variables and the reference counter afterwards. The reference counter is incremented each time an object is copied and will be decremented if it is destroyed.
Parameters
Member Function Documentation¶
void OpenDBX::Lob::close ()std::exception¶
Closes the large object and commits the changes. After reading from or writing new content into the large object, it should be closed to commit changes to the disk and clean up the resources. If this isn't done, the destructor of the object tries to close the large object automatically, but there's no guarantee it was successful as the destructor doesn't throw an exception in case of an error. Therefore, it's highly recommended to call this method once when you don't need the object any more.
Exceptions
Lob & OpenDBX::Lob::operator= (const Lob & ref)¶
Assign large object instance to another one. Assigns the internal state of an object ref of the same type to this object. Both objects share the same variables and the reference counter afterwards. The reference counter is incremented each time an object is copied and will be decremented if it is destroyed.
Parameters
Returns
ssize_t OpenDBX::Lob::read (void * buffer, size_t buflen)std::exception¶
Reads content from large object into the buffer. To get the content of a large object, this method fetches the data in one or more pieces from the server and stores it into the user supplied buffer. The first call to read() will return the bytes from the beginning. The second and all other calls will store subsequent parts of the large object content into the buffer until the end of the data is reached. To reread the content a second time, you have to close the large object handle and reopen it again as some databases provide no way to reposition the internal file position indicator for the stream. The large object content fetched from the server is stored into the user supplied buffer up to buflen bytes.
The method returns the number of bytes placed into buffer, which may be up to buflen bytes. If the end of the content is reached and no more data is available, the return value will be 0 (zero).
Parameters
buflen Length of the given buffer in bytes
Returns
Exceptions
ssize_t OpenDBX::Lob::write (void * buffer, size_t buflen)std::exception¶
Writes data from the buffer into the large object. It sends the data supplied in buffer to the server for storing it inside the large object. The function can be called more than once to add subsequent parts of the content to the object. If it isn't a new or empty object, the existing data will be overwritten and truncated to the new size. It's not possible to update only parts of the content as some databases doesn't support to position the internal file position indicator. The data which should be send to the server is read from buffer up to buflen bytes.
The method returns the number of bytes read from buffer and sent to the database server, which may be up to buflen bytes. It isn't guaranteed that the complete chunk was sent to the server, so the returned size may be less than the value in buflen.
Parameters
buflen Length of the data in the buffer in bytes
Returns
Exceptions
Author¶
Generated automatically by Doxygen for opendbx from the source code.
Sat Sep 21 2024 07:08:50 | Version 1.4.6 |