The pyocient module supports direct connections to the Ocient System through a command line interface (CLI) as well as Python programs that follow the Python Database API Specification 2.0. To download, install, and use the pyocient CLI, see Connect Using pyocient. The pyocient package has these supported features and functionality.Documentation Index
Fetch the complete documentation index at: https://docs.ocient.com/llms.txt
Use this file to discover all available pages before exploring further.
Prerequisites
To use the pyocient client, you should have this software with the corresponding version installed.| Software | Version |
|---|---|
| Ocient | All Ocient versions are supported. |
| OS | , , or . Use the latest version of each OS system. |
| Python | Version 3.8 or later. |
Module Features
The pyocient connector supports these features as of the current version.| Unicode Support | UTF-8 |
|---|---|
| Isolation Levels | Ocient does not support transactions at this time. |
| Data Types | Supports all Ocient Data Types. |
| Security / Encryption | GCM, CBC, and SSO protocols are supported. TLS protocol is optional as a setting. |
pyocient CLI
You can make a connection by invoking the pyocient module in a command-line interface with a connection string using this syntax. SyntaxShell
- Connecting Via a DSN
- Using SQL Queries in the CLI
- Using Named Arguments
- Additional pyocient CLI Commands
Connect Using a DSN
Required. A Data Source Name (DSN) supplies the user credentials, host, port, and database to establish a connection. This string can also include various optional parameters. SyntaxShell
| Argument | Definition |
|---|---|
<user> | Required. An Ocient username. |
<password> | Required. The password associated with your username for connection to Ocient. |
<host> | Required. The Ocient host address. You can specify multiple hosts if they are separated by commas. The system attempts to connect to multiple hosts in order, starting with the leftmost host. For example, host1 is the first for the connection attempt in this case: ocient://someone:somepassword@host1,host2:4051/mydb |
<port> | The port number used by your host. The default is 4050. |
<database> | The name of the database for the connection. The default is system. |
<parameters> | One or more optional parameters for the connection in the format parameter=value.Supported parameters include: tls: TLS protocol security. You can set the value to off, unverified, or on. The default is off.force: Values are true or false. If you set this value to true, this argument forces the connection to stay on this server. The default is false.handshake: Security handshake protocol. Supported values include cbc. By default, the system does not use cbc. identityprovider: An SSO integration established in the database. For details, see CREATE SSO INTEGRATION.ssoOAuthFlow: This parameter is only applicable if SSO authorization is enabled. Forces the driver to use either the authorizationCode or deviceGrant flow to establish a Single Sign-On session. If you do not specify this parameter, the system uses the authorizationCode flow when a web browser is available to the client and the deviceGrant flow when a web browser is not available to the client. |
Shell
SELECT query that you enter at the command line.
Shell
SQL Queries in the Connection String
Instead of executing queries and commands in the CLI, you can also include SQL scripts directly in your connection string. A connection string can contain multiple queries as long as each is delineated by semicolons. You must enclose any SQL statements in a connection string in quotes and specify the statements after the DSN portion. Example This example shows a SQL query embedded in a pyocient connection string. The query processes and returns its values without launching the interactive mode.Shell
Use Optional Named Arguments
You can add these optional arguments to a connection string.Shell
| Named Argument | Definition |
|---|---|
-o | --outfile OUTFILE | pyocient records all SQL output to a specified output file. You must also include the file path to the output file, enclosed in quotation marks. The Ocient System saves output values to the file after query completion. |
-n | --noout | Prevent all output results. |
-c | --configfile CONFIGFILE | Direct pyocient to use a configuration file. You must include the path location and name of the configuration file, enclosed in quotation marks. |
--noconfig | Direct pyocient not to use a configuration file. |
-i | --infile INFILE | Direct pyocient to use an input file that contains SQL statements. |
-l | --loglevel LOGLEVEL | Sets the logging level. Logging level options include: CRITICAL | ERROR | WARNING | INFO | DEBUGDefaults to CRITICAL. For details, see Log Monitoring. |
--logfile LOGFILE | Direct pyocient to record log events in a specified log file. You must include the path location and name of the log file, enclosed in quotation marks. |
-t, --time | pyocient outputs the execution time for all queries and commands. |
-f, --format | Specifies the output format for all SQL queries. Format options include: JSON | TABLE | CSV JSON — Object Notation. TABLE — A table rendered in ASCII characters. CSV — Comma-separated values format. The default value is JSON. |
--nocolor | When you use pyocient in interactive mode, the interface does not color SQL keywords. |
Additional pyocient CLI Commands
When running in a CLI, pyocient recognizes these commands in addition to the SQL statements and queries.| Command | Description |
|---|---|
CONNECT TO <dsn> USER <username> USING <password>; | Allows switching to a different DSN or user during an interactive session. The DSN must be enclosed in quotation marks. Otherwise, the command follows the normal format explained in Connect Using a DSN. You can specify the username and password either in the DSN string or with the USER and USING keywords. |
SOURCE '<file>'; | Executes the input statements from the specified file. The filename must be in single quotes. |
SET FORMAT TABLE; | Sets the output format. Format options include JSON, TABLE, and CSV. Defaults to JSON. JSON — JavaScript Object Notation. TABLE — A table rendered in ASCII characters. CSV — Comma-separated values format. |
QUIT; | Quits the CLI. Alternatively, you can exit the interface by using Ctrl + D. |
pyocient API
This Python database API conforms to the Python Database API Specification 2.0, and you can use it to access the Ocient System. You can also execute this module as a main function, in which case it acts as a primitive CLI for the database. When you execute this module as a main function, the API takes a connection string in the DSN format. The connection string can also include one or more query strings that execute. For information on using a DSN to connect, see Connect Using a DSN. The API returns output in JSON format by default. The database returns any warnings and sends them to the Python warnings module. By default, that module sends warnings to standard output, however, you can change the behavior by using that module.pyocient.Connection
Constructor
Python
connect(), but you can also construct it directly.
You can specify connection parameters using the dsn argument, other keyword arguments, or a mix of both. If the system receives multiple arguments for the same parameters, the keyword arguments take precedence and override the dsn value.
Definitions for the connection parameters are listed in Connect Using a DSN section. Other parameters are:
configfile— The name of a configuration file in .ini format, where each section either uses default connection settings or a pattern that matches the host or database. Sections are matched in order, so highly detailed sections should precede less detailed sections.session— A string of an SSO security token.
.ini configuration file.
INI
tls — The values are on, off, or unverified in the DSN. You can also set TLS by using Connection.TLS_NONE, Connection.TLS_UNVERIFIED, or Connection.TLS_ON as a keyword parameter.
Connection Object Methods
close()
Close the connection. Any subsequent queries on the closed connection fail.commit()
Commit any pending transactions to the database.cursor()
Return a new cursor object for this connection.pyocient.Cursor
Constructor
Python
cursor() on a connection, but you can also create them directly by providing a connection.
Cursor Object Methods
close()
Close this cursor. The current result set is closed, but you can reuse the cursor for subsequentexecute() calls.
execute(operation, parameters=None) [#execute]
Prepare and execute a database operation (query or command). Parameters might be provided as a mapping and are bound to variables in the operation. Variables are specified in Python extended format codes, for example:WHERE name=%(name)
executemany(operation, parameterlist)
Prepare a database operation (query or command) and then execute it against all parameter sequences or mappings found in the sequenceparameterlist.
Parameters might be provided as a mapping and are bound to variables in the operation. Variables are specified in Python extended format codes, for example: WHERE name=%(name)
fetchone()
Fetch the next row of a query result set. The function returns a single row orNone when no more data rows are available.
fetchmany(size=None) [#fetchmany]
Fetch the next set of rows of a query result and return a sequence of sequences as a list of tuples. The database returns an empty sequence when no more rows are available. The number of rows to fetch per call is specified by thesize parameter. If this parameter is not specified, the array size of the cursor determines the number of rows to fetch. The method tries to fetch as many rows as indicated by the size parameter. If this is not possible due to the specified number of rows not being available, the function returns fewer rows.
fetchall()
Fetch all (remaining) rows of a query result and return them as a sequence of sequences (e.g., a list of tuples). Note that the array size attribute of the cursor can affect the performance of this operation.arraysize
This read-and-write attribute specifies the number of rows to fetch at a time with fetchmany. The default value is1, meaning the attribute fetches a single row at a time.
tables(schema=’%’, table=’%’)
Retrieve the database tables. By default, the database returns all tables.system_tables(table=’%’)
Retrieve the database system tables.views(view=’%’)
Retrieve the database views.columns(schema=’%’, table=’%’, column=’%’)
Retrieve the database columns.indexes(schema=’%’, table=’%’)
Retrieve the database indexes.getTypeInfo()
Retrieve the database type information.fetchval()
The fetchval() convenience method returns the first column of the first row if there are results, otherwise it returnsNone.
resolve_new_endpoint(new_host, new_port)
Handles mapping to a secondary interface based on the secondary interface mapping saved on this connection. Arguments:Text
Text
redirect(new_host, new_port)
Redirects to the proper secondary interface with a new endpoint. Arguments:Text
Text
refresh()
Refresh the session associated with this connection. The server returns a new server session identifier and security token.setinputsizes(sizes)
Used before an execute call to set memory sizes for the specified operation. For details on usage, see the Python API documentation.setoutputsize(size [, column])
Used before an execute call to set a column buffer size for fetches of columns with large data types, such as LONG, BLOB, etc. For details on usage, see the Python API documentation.Type Objects and Constructors
These constructors create objects to hold special values to comply with defined types in a database schema. When you pass these objects to the cursor methods, the module detects the proper type of input parameter and binds it accordingly. For details, see the Python documentation on Type Objects and Constructors.Date(year, month, day)
This function constructs an object that holds a date value.Time(hour, minute, second)
This function constructs an object that holds a time value.Timestamp(year, month, day, hour, minute, second)
This function constructs an object that holds a timestamp value.DateFromTicks(ticks)
This function constructs an object that holds a date value from the specified ticks value (number of seconds after the epoch; see the documentation of the standard Python time module for details).TimeFromTicks(ticks)
This function constructs an object that holds a time value from the specified ticks value (number of seconds after the epoch; see the documentation of the standard Python time module for details).TimestampFromTicks(ticks)
This function constructs an object that holds a timestamp value from the specified ticks value (number of seconds after the epoch; see the documentation of the standard Python time module for details).Binary(string)
This function constructs an object capable of holding a binary (long) string value.STRING type
This type object describes columns in a database that are string-based (e.g.,CHAR).
BINARY type
This type object describes (long) binary columns in a database (e.g.,LONG, RAW, BLOB).
NUMBER type
This type object describes numeric columns in a database.DATETIME type
This type object describes date and time columns in a database.ROWID type
This type object describes the “Row ID” column in a database.Exceptions
Error Exception that is the base class of all other error exceptions.Text
Text
Text
Text
Text
Text
Text
Text
Text
Text
Optional DB API Extensions
Cursor.rownumber
This read-only attribute should provide the current 0-based index of the cursor in the result set orNone if the index cannot be determined.
You can see the index as the index of the cursor in a sequence (the result set). The next fetch operation fetches the row indexed by .rownumber in that sequence.
Connection.Error, Connection.ProgrammingError, etc.
All exception classes defined by the DB API standard should be exposed on the Connection objects as attributes (in addition to being available at module scope). These attributes simplify error handling in multi-connection environments.Cursor.connection
This read-only attribute returns a reference to the Connection object on which the cursor was created. The attribute simplifies writing polymorph code in multi-connection environments.Cursor.__iter__()
Return self to make cursors compatible with the Python iteration protocol.Related Links
pyocient PyPILinux® is the registered trademark of Linus Torvalds in the U.S. and other countries.

