|  |  |  | GNOME Data Access 4 manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Prerequisites | Known Implementations | ||||
GdaDataHandler; gchar * gda_data_handler_get_sql_from_value (GdaDataHandler *dh,const GValue *value); gchar * gda_data_handler_get_str_from_value (GdaDataHandler *dh,const GValue *value); GValue * gda_data_handler_get_value_from_sql (GdaDataHandler *dh,const gchar *sql,GType type); GValue * gda_data_handler_get_value_from_str (GdaDataHandler *dh,const gchar *str,GType type); GValue * gda_data_handler_get_sane_init_value (GdaDataHandler *dh,GType type); gboolean gda_data_handler_accepts_g_type (GdaDataHandler *dh,GType type); const gchar * gda_data_handler_get_descr (GdaDataHandler *dh);
GdaDataHandler is implemented by GdaHandlerBin, GdaHandlerBoolean, GdaHandlerNumerical, GdaHandlerString, GdaHandlerTime and GdaHandlerType.
Because data types vary a lot from a DBMS to another, the GdaDataHandler interface helps managing data in its various representations, and converting from one to another:
as a GValue which is a generic value container for the C language
as a human readable string
as an SQL string (a string which can be used in SQL statements)
  For each data type, a corresponding GdaDataHandler object can be requested using the
  gda_get_default_handler() function. However, when working
  with a specific database provider, it's better to use a GdaDataHandler which may be specific to the
  database provider which will correctly handle each database specifics using
  gda_server_provider_get_data_handler_g_type() or
  gda_server_provider_get_data_handler_dbms().
gchar * gda_data_handler_get_sql_from_value (GdaDataHandler *dh,const GValue *value);
Creates a new string which is an SQL representation of the given value, the returned string
can be used directly in an SQL statement. For example if value is a G_TYPE_STRING, then
the returned string will be correctly quoted. Note however that it is a better practice
to use variables in statements instead of value literals, see
the GdaSqlParser for more information.
If the value is NULL or is of type GDA_TYPE_NULL,
or is a G_TYPE_STRING and g_value_get_string() returns NULL, the returned string is "NULL".
| 
 | an object which implements the GdaDataHandler interface | 
| 
 | the value to be converted to a string | 
| Returns : | the new string, or NULLif an error occurred. [transfer full] | 
gchar * gda_data_handler_get_str_from_value (GdaDataHandler *dh,const GValue *value);
Creates a new string which is a "user friendly" representation of the given value (in the user's locale, specially for the dates). If the value is NULL or is of type GDA_TYPE_NULL, the returned string is a copy of "" (empty string).
| 
 | an object which implements the GdaDataHandler interface | 
| 
 | the value to be converted to a string | 
| Returns : | the new string, or NULLif an error occurred. [transfer full] | 
GValue * gda_data_handler_get_value_from_sql (GdaDataHandler *dh,const gchar *sql,GType type);
Creates a new GValue which represents the SQL value given as argument. This is
the opposite of the function gda_data_handler_get_sql_from_value(). The type argument
is used to determine the real data type requested for the returned value.
If the sql string is NULL, then the returned GValue is of type GDA_TYPE_NULL;
if the sql string does not correspond to a valid SQL string for the requested type, then
the NULL is returned.
| 
 | an object which implements the GdaDataHandler interface | 
| 
 | an SQL string | 
| 
 | a GType | 
| Returns : | the new GValue or NULLon error. [transfer full] | 
GValue * gda_data_handler_get_value_from_str (GdaDataHandler *dh,const gchar *str,GType type);
Creates a new GValue which represents the str value given as argument. This is
the opposite of the function gda_data_handler_get_str_from_value(). The type argument
is used to determine the real data type requested for the returned value.
If the str string is NULL, then the returned GValue is of type GDA_TYPE_NULL;
if the str string does not correspond to a valid string for the requested type, then
NULL is returned.
| 
 | an object which implements the GdaDataHandler interface | 
| 
 | a string | 
| 
 | a GType | 
| Returns : | the new GValue or NULLon error. [transfer full] | 
GValue * gda_data_handler_get_sane_init_value (GdaDataHandler *dh,GType type);
Creates a new GValue which holds a sane initial value to be used if no value is specifically provided. For example for a simple string, this would return a new value containing the "" string.
| 
 | an object which implements the GdaDataHandler interface | 
| 
 | a GType | 
| Returns : | the new GValue, or NULLif no such value can be created. [transfer full] | 
gboolean gda_data_handler_accepts_g_type (GdaDataHandler *dh,GType type);
Checks wether the GdaDataHandler is able to handle the gda type given as argument.
| 
 | an object which implements the GdaDataHandler interface | 
| 
 | a GType | 
| Returns : | TRUEif the gda type can be handled | 
const gchar *       gda_data_handler_get_descr          (GdaDataHandler *dh);
Get a short description of the GdaDataHandler
| 
 | an object which implements the GdaDataHandler interface | 
| Returns : | the description. [transfer none] |