|  |  |  | GNOME Data Access 4 manual |  | 
|---|
Libgda allows data sources (DSN) to be defined and refered to by a unique name which contains all the required information to actually open a connection (except the name and password if they are required); see the Configuration section for more information about how to manage data sources. Of course it's still possible to open a connection without having defined a DSN, in which case a connection string is used to specify all the parameters resuired to open a connection. For more information about connection strings, see the gda_connection_open_from_string ()'s documentation.
Connections are opened using gda_connection_open_from_dsn () for connections which are defined as a data source (DSN), or or gda_connection_open_from_string () otherwise. Each connection object can then be used to actually execute queries, for example:
void
do_stuff () {
	GdaConnection *connection;
      
        /* open a connection */
	g_print ("CONNECTING\n");
	connection = gda_connection_open_from_dsn ("calvaris", NULL, 
                                                   GDA_CONNECTION_OPTIONS_READ_ONLY, NULL);
	if (!connection) {
		g_print ("CONNECTION FAILED\n");
		return;
	}
	g_print ("CONNECTED\n");
      
        /* use the connection */
	execute_some_queries (connection);
      
        /* close the connection */
        g_object_unref (G_OBJECT (connection));
}
      
Closing the connection can be ordered using gda_connection_close (), or is automatically done when the connection object is destroyed (as is the case in the example abive when g_object_unref() is called with the connection as argument).