MySQL Shell API 9.0.0
Unified development interface for MySQL Products
Methods | Properties | List of all members
ClassicSession Class Reference

Enables interaction with a MySQL Server using the MySQL Protocol. More...

Methods

void close () override
 Closes the internal connection to the MySQL Server held on this session object.
 
void commit () override
 Commits all the operations executed after a call to startTransaction(). More...
 
void rollback () override
 Discards all the operations executed after a call to startTransaction(). More...
 
String getUri ()
 Retrieves the URI for the current session. More...
 
String getSshUri ()
 Retrieves the SSH URI for the current session. More...
 
Integer getConnectionId ()
 Retrieves the connection id for the current session. More...
 
ClassicResult runSql (String query, Array args=[])
 Executes a query and returns the corresponding ClassicResult object. More...
 
ClassicResult startTransaction ()
 Starts a transaction context on the server. More...
 
Bool isOpen ()
 Returns true if session is known to be open. More...
 
Undefined setQueryAttributes (Dictionary attributes)
 Defines query attributes that apply to the next statement sent to the server for execution. More...
 

Properties

String uri
 Retrieves the URI for the current session.
 
String sshUri
 Retrieves the SSH URI for the current session.
 
Integer connectionId
 Retrieves the connection id for the current session.
 

Detailed Description

Enables interaction with a MySQL Server using the MySQL Protocol.

Provides facilities to execute queries.

// Begins a transaction
classicSession.startTransaction();
// Inserts some records
var res1 = classicSession.runSql('insert into sample values ("john")');
var res2 = classicSession.runSql('insert into sample values ("carol")');
var res3 = classicSession.runSql('insert into sample values ("jack")');
// Commits the transaction
classicSession.commit();

Member Function Documentation

◆ commit()

void commit ( )
override

Commits all the operations executed after a call to startTransaction().

All the operations executed after calling startTransaction() will take place when this function is called.

The server autocommit mode will return back to it's state before calling startTransaction().

◆ rollback()

void rollback ( )
override

Discards all the operations executed after a call to startTransaction().

All the operations executed after calling startTransaction() will be discarded when this function is called.

The server autocommit mode will return back to it's state before calling startTransaction().

◆ getUri()

String getUri ( )

Retrieves the URI for the current session.

Returns
A string representing the connection data.

◆ getSshUri()

String getSshUri ( )

Retrieves the SSH URI for the current session.

Returns
A string representing the SSH connection data.

◆ getConnectionId()

Integer getConnectionId ( )

Retrieves the connection id for the current session.

Returns
An integer value representing the connection id.

◆ runSql()

ClassicResult runSql ( String  query,
Array  args = [] 
)

Executes a query and returns the corresponding ClassicResult object.

Parameters
querythe SQL query to execute against the database.
argsOptional list of literals to use when replacing ? placeholders in the query string.
Returns
A ClassicResult object.
Exceptions
LogicErrorif there's no open session.
ArgumentErrorif the parameters are invalid.

◆ startTransaction()

Undefined startTransaction ( )

Starts a transaction context on the server.

Calling this function will turn off the autocommit mode on the server.

All the operations executed after calling this function will take place only when commit() is called.

All the operations executed after calling this function, will be discarded if rollback() is called.

When commit() or rollback() are called, the server autocommit mode will return back to it's state before calling startTransaction().

◆ isOpen()

Bool isOpen ( )

Returns true if session is known to be open.

Returns
A boolean value indicating if the session is still open.

Returns true if the session is still open and false otherwise.

Note
This function may return true if connection is lost.

◆ setQueryAttributes()

Undefined setQueryAttributes ( Dictionary  attributes)

Defines query attributes that apply to the next statement sent to the server for execution.

It is possible to define up to 32 pairs of attribute and values for the next executed SQL statement.

To access query attributes within SQL statements for which attributes have been defined, the query_attributes component must be installed, this component implements a mysql_query_attribute_string() loadable function that takes an attribute name argument and returns the attribute value as a string, or NULL if the attribute does not exist.

To install the query_attributes component execute the following statement:

session.runSql('INSTALL COMPONENT "file://component_query_attributes"');