Top |
This object is a base class for individual database providers which support BLOB types. It supports operations to read and write data in a BLOB value (of type GDA_BLOB_TYPE).
Libgda offers two methods to manipulate binary values as two containers: GdaBinary and GdaBlob:
When reading from a data model returned by Libgda binary data will often be in a GdaBlob object, and the associated GdaBlobOp object can be used to manipulate the binary object (in a database for example)
When the binary value is created by the user, then there is no point in using a GdaBlob as there can not be any GdaBlobOp object, so the GdaBinary container is enough.
Note that a GdaBlob value (the "data" attribute) will often not contain any data (or only some part of the actual BLOB) and that it's up to the user to use the associated GdaBlobOp object to "load" the data into the container (into the actual process heap).
For example to load the 1st 40 bytes of a blob:
GValue *blob_value = ... GdaBlob *blob; blob = (GdaBlob*) gda_value_get_blob (blob_value); gda_blob_op_read (blob->op, blob, 0, 40);
Another example is to write the contents of a blob to a file on disk, using a special
GdaBlobOp object (internal to Libgda which interfaceswith a file in a filesystem):
GValue *blob_value; // value to copy from GValue *tmp_value; GdaBlob *file_blob; GValue *blob_value = ... tmp_value = gda_value_new_blob_from_file ("MyFile.bin"); file_blob = (GdaBlob*) gda_value_get_blob (tmp_value); if (! gda_blob_op_write_all (file_blob->op, gda_value_get_blob (blob_value))) { // error } else { gsize size; size = gda_blob_op_get_length (file_blob->op); g_print ("Wrote %s, size = %d\n", filename, size); } gda_value_free (tmp_value);
For further information, see:
the section about Binary large objects (BLOBs)'s abstraction
Virtual methods for Blob operations section for more information about how to implement the virtual methods when creating a database provider
glong
gda_blob_op_get_length (GdaBlobOp *op
);
the length of the blob in bytes. In case of error, -1 is returned and the provider should have added an error (a GdaConnectionEvent) to the connection.
glong gda_blob_op_read (GdaBlobOp *op
,GdaBlob *blob
,glong offset
,glong size
);
Reads a chunk of bytes from the BLOB accessible through op
into blob
.
gboolean gda_blob_op_read_all (GdaBlobOp *op
,GdaBlob *blob
);
Reads the whole contents of the blob manipulated by op
into blob
glong gda_blob_op_write (GdaBlobOp *op
,GdaBlob *blob
,glong offset
);
Writes a chunk of bytes from a blob
to the BLOB accessible through op
, blob
is unchanged after
this call.
If blob
has an associated GdaBlobOp (ie. if blob->op
is not NULL
) then the data to be written
using op
is the data fetched using blob->op
.