Gjsify LogoGjsify Logo

Index

Enumerations

Classes

Interfaces

Type Aliases

Variables

Functions

Type Aliases

Mutex: RecMutex
SqlBuilderId: number
SqlErrorType: Gda.SqlError

Variables

ATTRIBUTE_AUTO_INCREMENT: string

The corresponding attribute specifies if the object it refers to is auto incremented (value has a G_TYPE_BOOLEAN type).

ATTRIBUTE_DESCRIPTION: string

The corresponding attribute is the description of the object it refers to (value has a G_TYPE_STRING type).

ATTRIBUTE_IS_DEFAULT: string

The corresponding attribute specifies if the object it refers to has its value to default (value has a G_TYPE_BOOLEAN type).

ATTRIBUTE_NAME: string

The corresponding attribute is the name of the object it refers to (value has a G_TYPE_STRING type).

ATTRIBUTE_NUMERIC_PRECISION: string

The corresponding attribute is the number of significant digits of the object it refers to (value has a G_TYPE_INT type).

ATTRIBUTE_NUMERIC_SCALE: string

The corresponding attribute is the number of significant digits to the right of the decimal point of the object it refers to (value has a G_TYPE_INT type).

ATTRIBUTE_TREE_NODE_UNKNOWN_CHILDREN: string

This attribute, if %TRUE specifies that a tree node may or may not have any children nodes (value has a G_TYPE_BOOLEAN type).

EXTRA_AUTO_INCREMENT: string
SQLSTATE_GENERAL_ERROR: string
SQLSTATE_NO_ERROR: string
TIMEZONE_INVALID: number

Functions

  • alphanum_to_text(text: string): string
  • Does the opposite of gda_text_to_alphanum(), in the same string

    Parameters

    • text: string

      a string

    Returns string

  • binary_copy(boxed: object): object | null
  • Creates a new #GdaBinary structure from an existing one.

    Parameters

    • boxed: object

      source to get a copy from.

    Returns object | null

  • binary_free(boxed: object): void
  • Deallocates all memory associated to the given #GdaBinary.

    Parameters

    • boxed: object

      #GdaBinary to free.

    Returns void

  • blob_copy(boxed: object): object | null
  • Creates a new #GdaBlob structure from an existing one.

    Parameters

    • boxed: object

      source to get a copy from.

    Returns object | null

  • blob_free(boxed: object): void
  • Deallocates all memory associated to the given #GdaBlob.

    Parameters

    • boxed: object

      #GdaBlob to free.

    Returns void

  • completion_list_get(cnc: Gda.Connection, sql: string, start: number, end: number): string[] | null
  • Creates an array of strings (terminated by a %NULL) corresponding to possible completions. If no completion is available, then the returned array contains just one NULL entry, and if it was not possible to try to compute a completions list, then %NULL is returned.

    Parameters

    • cnc: Gda.Connection

      a #GdaConnection object

    • sql: string

      a partial SQL statement which is the context of the completion proposal

    • start: number

      starting position within sql of the "token" to complete (starts at 0)

    • end: number

      ending position within sql of the "token" to complete

    Returns string[] | null

  • Creates an INSERT, an UPDATE and a DELETE statement from a SELECT statement using the database metadata available in cnc's meta store. Each statements are computed only if the corresponding place to store the created statement is not %NULL.

    Parameters

    • cnc: Gda.Connection

      a #GdaConnection

    • select_stmt: Gda.Statement

      a SELECT #GdaStatement (compound statements not handled)

    • require_pk: boolean

      TRUE if the created statement have to use a primary key

    • insert_stmt: Gda.Statement

      a place to store the created INSERT statement, or %NULL

    • update_stmt: Gda.Statement

      a place to store the created UPDATE statement, or %NULL

    • delete_stmt: Gda.Statement

      a place to store the created DELETE statement, or %NULL

    Returns boolean

  • Obtain a pointer to a #GdaDataHandler which can manage #GValue values of type for_type. The returned data handler will be adapted to use the current locale information (for example dates will be formatted taking into account the locale).

    The returned pointer is %NULL if there is no default data handler available for the for_type data type

    Parameters

    • for_type: GType<unknown>

      a #GType type

    Returns Gda.DataHandler

  • data_model_error_quark(): Quark
  • default_escape_string(string: string): string
  • Escapes string to make it understandable by a DBMS. The escape method is very common and replaces any occurrence of "'" with "''" and "" with "\"

    Parameters

    • string: string

      string to escape

    Returns string

  • default_unescape_string(string: string): string
  • Do the reverse of gda_default_escape_string(): transforms any "''" into "'", any "\" into "" and any "'" into "'".

    Parameters

    • string: string

      string to unescape

    Returns string

  • dsn_split(string: string, out_dsn: string, out_username: string, out_password: string): void
  • Extract the DSN, username and password from string. in string, the various parts are strings which are expected to be encoded using an RFC 1738 compliant encoding. If they are specified, the returned username and password strings are correctly decoded.

    out_username and out_password may be set to %NULL depending on string's format.

    Parameters

    • string: string

      a string in the "[<username>[:<password>]]<DSN>" form

    • out_dsn: string

      a place to store the new string containing the <DSN> part

    • out_username: string

      a place to store the new string containing the <username> part

    • out_password: string

      a place to store the new string containing the <password> part

    Returns void

  • g_type_from_string(str: string): GType
  • Converts a named type to ts GType type (also see the gda_g_type_to_string() function).

    This function is a wrapper around the g_type_from_name() function, but also recognizes some type synonyms such as: "int" for G_TYPE_INT "uint" for G_TYPE_UINT "int64" for G_TYPE_INT64 "uint64" for G_TYPE_UINT64 "char" for G_TYPE_CHAR "uchar" for G_TYPE_UCHAR "short" for GDA_TYPE_SHORT "ushort" for GDA_TYPE_USHORT "string" for G_TYPE_STRING "date" for G_TYPE_DATE "time" for GDA_TYPE_TIME "timestamp" for GDA_TYPE_TIMESTAMP "boolean" for G_TYPE_BOOLEAN "blob" for GDA_TYPE_BLOB "binary" for GDA_TYPE_BINARY "null" for GDA_TYPE_NULL

    Parameters

    • str: string

      the name of a #GType, as returned by gda_g_type_to_string().

    Returns GType

  • g_type_to_string(type: GType<unknown>): string
  • Converts a GType to its string representation (use gda_g_type_from_string() for the operation in the other direction).

    This function wraps g_type_name() but for common types it provides an easier to understand and remember name. For Example the G_TYPE_STRING is converted to "string" whereas g_type_name() converts it to "gchararray".

    Parameters

    • type: GType<unknown>

      Type to convert from.

    Returns string

  • geometricpoint_copy(boxed: object): object | null
  • geometricpoint_free(boxed: object): void
  • get_application_exec_path(app_name: string): string
  • Find the path to the application identified by app_name. For example if the application is "gda-sql", then calling this function will return "/your/prefix/bin/gda-sql-5.0" if Libgda is installed in the "/your/prefix" prefix (which would usually be "/usr"), and for the ABI version 5.0.

    Parameters

    • app_name: string

      the name of the application to find

    Returns string

  • identifier_equal(id1: string, id2: string): boolean
  • Does the same as strcmp(id1, id2), but handles the case where id1 and/or id2 are enclosed in double quotes. can also be used in hash tables as a #GEqualFunc.

    Parameters

    • id1: string

      an identifier string

    • id2: string

      an identifier string

    Returns boolean

  • identifier_hash(id: string): number
  • computes a hash string from id, to be used in hash tables as a #GHashFunc

    Parameters

    • id: string

      an identifier string

    Returns number

  • init(): void
  • Initializes the GDA library, must be called prior to any Libgda usage.

    Please note that if you call setlocale() to modify the current locale, you should also call gda_locale_changed() before using Libgda again.

    Returns void

  • locale_changed(): void
  • Call this function whenever the setlocale() function has been called to change the current locale; this function is first called by gda_init() so you don't need to call it if you have set the locale before calling gda_init().

    Failing to call this function after having changed the current locale may result in Libgda reverting to the previous set locale.

    Returns void

  • log_disable(): void
  • log_enable(): void
  • log_is_enabled(): boolean
  • This function is similar to gda_parse_iso8601_date() (with first being G_DATE_YEAR, second being G_DATE_MONTH, third being G_DATE_DAY and sep being '-') but allows one to specify the expected date format.

    Parameters

    • gdate: GLib.Date

      a pointer to a #GDate structure which will be filled

    • value: string

      a string to be parsed

    • first: DateDMY

      a #GDateDMY specifying which of year, month or day appears first (in the first bytes) in value

    • second: DateDMY

      a #GDateDMY specifying which of year, month or day appears second (in the first bytes) in value

    • third: DateDMY

      a #GDateDMY specifying which of year, month or day appears third (in the first bytes) in value

    • sep: number

      spcifies the expected separator character bewteen year, month and day (for example '-')

    Returns boolean

  • parse_formatted_time(timegda: Gda.Time, value: string, sep: number): boolean
  • This function is similar to gda_parse_iso8601_timestamp() (with first being G_DATE_YEAR, second being G_DATE_MONTH, third being G_DATE_DAY and sep being '-') but allows one to specify the expected date format.

    Parameters

    • timestamp: Gda.Timestamp

      a pointer to a #GdaTimeStamp structure which will be filled

    • value: string

      a string to be parsed

    • first: DateDMY

      a #GDateDMY specifying which of year, month or day appears first (in the first bytes) in value

    • second: DateDMY

      a #GDateDMY specifying which of year, month or day appears second (in the first bytes) in value

    • third: DateDMY

      a #GDateDMY specifying which of year, month or day appears third (in the first bytes) in value

    • sep: number

      spcifies the expected separator character bewteen year, month and day (for example '-')

    Returns boolean

  • parse_iso8601_date(gdate: GLib.Date, value: string): boolean
  • Extracts date parts from value, and sets gdate's contents

    Accepted date format is "YYYY-MM-DD" (more or less than 4 digits for years and less than 2 digits for month and day are accepted). Years must be in the 1-65535 range, a limitation imposed by #GDate.

    Parameters

    • gdate: GLib.Date

      a pointer to a #GDate structure which will be filled

    • value: string

      a string

    Returns boolean

  • parse_iso8601_time(timegda: Gda.Time, value: string): boolean
  • Extracts time parts from value, and sets timegda's contents

    Accepted date format is "HH:MM:SS[.ms][TZ]" where TZ is +hour or -hour

    Parameters

    • timegda: Gda.Time

      a pointer to a #GdaTime structure which will be filled

    • value: string

      a string

    Returns boolean

  • parse_iso8601_timestamp(timestamp: Gda.Timestamp, value: string): boolean
  • Extracts date and time parts from value, and sets timestamp's contents

    Accepted date format is "YYYY-MM-DD HH:MM:SS[.ms][TZ]" where TZ is +hour or -hour

    Parameters

    • timestamp: Gda.Timestamp

      a pointer to a #GdaTimeStamp structure which will be filled

    • value: string

      a string

    Returns boolean

  • Modifies stmt to take into account any parameter which might be %NULL: if stmt contains the equivalent of "xxx = <parameter definition>" and if that parameter is in params and its value is of type GDA_TYPE_NUL, then that part is replaced with "xxx IS NULL". It also handles the "xxx IS NOT NULL" transformation.

    For example the following SELECT: SELECT * FROM data WHERE id = ##id::int::null AND name = ##name::string in case the "id" parameter is set to NULL, is converted to: SELECT * FROM data WHERE id IS NULL AND name = ##name::string

    if out_stmt is not %NULL, then it will contain: the modified statement if some modifications were required and no error occured (the function returns %TRUE) %NULL if no modification to stmt were required and no erro occurred (the function returns %FALSE) %NULL if an error occured (the function returns %TRUE)

    This function is used by provider's implementations to make sure one can use parameters with NULL values in statements without having to rewrite statements, as database usually don't consider that "xxx = NULL" is the same as "xxx IS NULL" when using parameters.

    Parameters

    • stmt: Gda.Statement

      a #GdaStatement

    • params: Gda.Set

      a #GdaSet to be used as parameters when executing stmt

    • out_stmt: Gda.Statement

      a place to store the new #GdaStatement, or %NULL

    Returns boolean

  • rfc1738_decode(string: string): boolean
  • Decodes string using the RFC 1738 recommendations: the <>"#%{}|^~[]';/?:=`& and space characters are replaced by "%%ab" where ab is the hexadecimal number corresponding to the character.

    string should respect the RFC 1738 encoding. If this is not the case (for example if there is a "%2z" because 2z is not an hexadecimal value), then the part with the problem is not decoded, and the function returns FALSE.

    string is decoded in place, no new string gets created.

    Parameters

    • string: string

      a string to decode

    Returns boolean

  • rfc1738_encode(string: string): string
  • Encodes string using the RFC 1738 recommendations: the <>"#%{}|^~[]';/?:=`& and space characters are replaced by "%%ab" where ab is the hexadecimal number corresponding to the character.

    Parameters

    • string: string

      a string to encode

    Returns string

  • Creates a new #GdaStatement, selecting the same data as stmt, but which always returns an empty (no row) data model. This is use dy database providers' implementations.

    Parameters

    Returns Gda.Statement

  • Use this function for any SQL identifier to make sure that: it is correctly formatted to be used with cnc (if cnc is %NULL, then some default SQL quoting rules will be applied, similar to PostgreSQL's way) if for_meta_store is %FALSE; it is correctly formatted to be used with the #GdaMetaStore's object associated to cnc is for_meta_store is %TRUE.

    The force_quotes allow some control of how to interpret id: if %FALSE, then id will be left unchanged most of the time (except for example if it's a reserved keyword), otherwise if force_quotes is %TRUE, then the returned string will most probably have quotes around it to request that the database keep the case sensitiveness (but again, this may vary depending on the database being accessed through cnc).

    For example, the following table gives the result of this function depending on the arguments when cnc is %NULL (and prov is also %NULL):

    id for_meta_store=%FALSE, force_quotes=%FALSE for_meta_store=%TRUE, force_quotes=%FALSE for_meta_store=%FALSE, force_quotes=%TRUE for_meta_store=%TRUE, force_quotes=%TRUE remark "double word" "double word" "double word" "double word" "double word" non allowed character in SQL identifier "CapitalTest" "CapitalTest" "CapitalTest" "CapitalTest" "CapitalTest" Mixed case SQL identifier, already quoted CapitalTest CapitalTest capitaltest "CapitalTest" "CapitalTest" Mixed case SQL identifier, non quoted "mytable" "mytable" mytable "mytable" mytable All lowser case, quoted mytable mytable mytable "mytable" mytable All lowser case MYTABLE MYTABLE mytable "MYTABLE" "MYTABLE" All upper case "MYTABLE" "MYTABLE" "MYTABLE" "MYTABLE" "MYTABLE" All upper case, quoted desc "desc" "desc" "desc" "desc" SQL reserved keyword 5ive "5ive" "5ive" "5ive" "5ive" SQL identifier starting with a digit

    Here are a few examples of when and how to use this function: When creating a table, the user has entered the table name, this function can be used to create a valid SQL identifier from the user provided table name: gchar user_sqlid=... gchar valid_sqlid = gda_sql_identifier_quote (user_sqlid, cnc, NULL, FALSE, FALSE); gchar sql = g_strdup_printf ("CREATE TABLE %s ...", valid_sqlid); g_free (valid_sqlid); Note that this is an illustration and creating a table should be sone using a #GdaServerOperation object. When updating the meta data associated to a table which has been created with the code above: GValue table_name_value = { 0 }; gchar column_names[] = { (gchar)"table_name" }; GValue column_values[] = { &table_name_value }; GdaMetaContext mcontext = { (gchar*)"_tables", 1, column_names, column_values }; g_value_init (&table_name_value, G_TYPE_STRING); g_value_take_string (&table_name_value, gda_sql_identifier_quote (user_sqlid, cnc, NULL, TRUE, FALSE); gda_connection_update_meta_store (cnc, &mcontext, NULL); g_value_reset (&table_name_value); When using a #GdaMetaStruct object to fetch information about a table (which has been created with the code above): GValue table_name_value = { 0 }; g_value_init (&table_name_value, G_TYPE_STRING); g_value_take_string (&table_name_value, gda_sql_identifier_quote (user_sqlid, cnc, NULL, TRUE, FALSE); GdaMetaDbObject *dbo; dbo = gda_meta_struct_complement (mstruct, GDA_META_DB_TABLE, NULL, NULL, &table_name_value, NULL); g_value_reset (&table_name_value);

    Note that id must not be a composed SQL identifier (such as "mytable.mycolumn" which should be treated as the "mytable" and "mycolumn" SQL identifiers). If unsure, use gda_sql_identifier_split().

    Also note that if cnc is %NULL, then it's possible to pass an non %NULL prov to have a result specific to prov.

    For more information, see the SQL identifiers and abstraction and

    SQL identifiers in meta data sections.

    Parameters

    • id: string

      an SQL identifier

    • cnc: Gda.Connection

      a #GdaConnection object, or %NULL

    • prov: Gda.ServerProvider

      a #GdaServerProvider object, or %NULL for_meta_store set to %TRUE if the returned string will be used in a #GdaMetaStore

    • meta_store_convention: boolean
    • force_quotes: boolean

      set to %TRUE to force the returned string to be quoted

    Returns string

  • sql_identifier_split(id: string): string[] | null
  • Splits id into an array of it sub parts. id's format has to be "<part>[.<part>[...]]" where each part is either a text surrounded by double quotes which can contain upper and lower cases or an SQL identifier in lower case.

    For example the string will result in the array:

    Parameters

    • id: string

      an SQL identifier

    Returns string[] | null

  • Performs the reverse of gda_binary_to_string() (note that for any "\xyz" succession of 4 characters where "xyz" represents a valid octal value, the resulting read value will be modulo 256).

    I str is %NULL, then an empty (i.e. where the data part is %NULL) #GdaBinary is created and returned.

    Parameters

    • str: string

      a string to convert, or %NULL

    Returns Gda.Binary

  • string_to_blob(str: string): Gda.Blob
  • text_to_alphanum(text: string): string
  • The "encoding" consists in replacing non alphanumeric character with the string "__gdaXX" where XX is the hex. representation of the non alphanumeric char.

    Parameters

    • text: string

      the text to convert

    Returns string

  • time_copy(boxed: object): object | null
  • time_free(boxed: object): void
  • timestamp_copy(boxed: object): object | null
  • timestamp_free(boxed: object): void
  • Check the column types of a GdaDataModel.

    Parameters

    • model: Gda.DataModel

      a #GdaDataModel object

    • types: GType<unknown>[]

      array with nbcols length of type GType or null (if any data type is accepted)

    Returns boolean

  • utility_data_model_dump_data_to_xml(model: Gda.DataModel, parent: NodePtr, cols: number[], rows: number[], use_col_ids: boolean): boolean
  • Dump the data in a #GdaDataModel into a xmlNodePtr (as used in libxml).

    Warning: this function uses a #GdaDataModelIter iterator, and if model does not offer a random access (check using gda_data_model_get_access_flags()), the iterator will be the same as normally used to access data in model previously to calling this method, and this iterator will be moved (point to another row).

    Parameters

    • model: Gda.DataModel

      a #GdaDataModel

    • parent: NodePtr

      the parent XML node

    • cols: number[]

      an array containing which columns of model will be exported, or %NULL for all columns

    • rows: number[]

      an array containing which rows of model will be exported, or %NULL for all rows

    • use_col_ids: boolean

      set to %TRUE to add column ID information

    Returns boolean

  • utility_data_model_find_column_description(model: Gda.DataSelect, field_name: string): string
  • Finds the description of a field into Metadata from a #GdaDataModel.

    Parameters

    • model: Gda.DataSelect

      a #GdaDataSelect data model

    • field_name: string

      field name

    Returns string

  • value_compare(value1: any, value2: any): number
  • Compares two values of the same type, with the exception that a value of any type can be compared to a GDA_TYPE_NULL value, specifically: if value1 and value2 are both GDA_TYPE_NULL values then the returned value is 0 if value1 is a GDA_TYPE_NULL value and value2 is of another type then the returned value is -1 if value1 is of another type and value2 is a GDA_TYPE_NULL value then the returned value is 1 in all other cases, value1 and value2 must be of the same type and their values are compared

    Parameters

    • value1: any

      a #GValue to compare (not %NULL)

    • value2: any

      the other #GValue to be compared to value1 (not %NULL)

    Returns number

  • value_differ(value1: any, value2: any): number
  • Tells if two values are equal or not, by comparing memory representations. Unlike gda_value_compare(), the returned value is boolean, and gives no idea about ordering.

    The two values must be of the same type, with the exception that a value of any type can be compared to a GDA_TYPE_NULL value, specifically: if value1 and value2 are both GDA_TYPE_NULL values then the returned value is 0 if value1 is a GDA_TYPE_NULL value and value2 is of another type then the returned value is 1 if value1 is of another type and value2 is a GDA_TYPE_NULL value then the returned value is 1 in all other cases, value1 and value2 must be of the same type and their values are compared

    Parameters

    • value1: any

      a #GValue to compare.

    • value2: any

      the other #GValue to be compared to value1.

    Returns number

  • value_stringify(value: any): string
  • Converts a GValue to its string representation which is a human readable value. Note that the returned string does not take into account the current locale of the user (on the contrary to the #GdaDataHandler objects). Using this function should be limited to debugging and values serialization purposes.

    Output is in the "C" locale for numbers, and dates are converted in a YYYY-MM-DD format.

    Parameters

    • value: any

      a #GValue.

    Returns string

Legend

  • Module
  • Object literal
  • Variable
  • Function
  • Function with type parameter
  • Index signature
  • Type alias
  • Type alias with type parameter
  • Enumeration
  • Enumeration member
  • Property
  • Method
  • Interface
  • Interface with type parameter
  • Constructor
  • Property
  • Method
  • Index signature
  • Class
  • Class with type parameter
  • Constructor
  • Property
  • Method
  • Accessor
  • Index signature
  • Inherited constructor
  • Inherited property
  • Inherited method
  • Inherited accessor
  • Protected property
  • Protected method
  • Protected accessor
  • Private property
  • Private method
  • Private accessor
  • Static property
  • Static method