Skip to main content

module resource::jdbc::JDBC

rascal-0.34.0

Usage

import resource::jdbc::JDBC;

Dependencies

import Exception;
import Type;
import Map;
import String;
import List;
import Set;
import IO;
import lang::rascal::types::AbstractType;

function registerJDBCClass

Given the name of a JDBC driver class, register it so it can be used in connections.

void registerJDBCClass(str className)

function mysqlConnectString

Generate a MySQL connect string.

str mysqlConnectString(map[str,str] properties)

data Connection

JDBC Connection type

data Connection  
= jdbcConnection(int id)
;

function createConnection

Create a connection based on the given connection string.

Connection createConnection(str connectString)

function closeConnection

Close the given connection.

void closeConnection(Connection connection)

function getTableTypes

Get the types of tables available through this connection.

list[str] getTableTypes(Connection connection)

data JDBCType

The JDBC types that could be assigned to various columns.

data JDBCType  
= array()
| bigInt()
| binary()
| bit()
| blob()
| boolean()
| char()
| clob()
| dataLink()
| date()
| decimal()
| distinct()
| double()
| float()
| integer()
| javaObject()
| longNVarChar()
| longVarBinary()
| longVarChar()
| nChar()
| nClob()
| null()
| numeric()
| nVarChar()
| other()
| \real()
| ref()
| rowId()
| smallInt()
| sqlXML()
| struct()
| time()
| timeStamp()
| tinyInt()
| varBinary()
| varChar()
;

data Column

A column in a table or view

data Column  
= column(str columnName, JDBCType columnType, bool nullable)
;

data Table

A table in a database

data Table  
= table(str tableName, list[Column] columns)
;

function getTableNames

Get the tables visible through this connection (just names).

set[str] getTableNames(Connection connection)

function getTables

Get the tables visible through this connection (with column info).

set[Table] getTables(Connection connection)

function getViews

Get the tables visible through this connection (with column info).

set[Table] getViews(Connection connection)

function getTable

Get the Table metadata for a named table.

Table getTable(Connection connection, str tableName)

function getView

Get the Table metadata for a named view.

Table getView(Connection connection, str viewName)

data RuntimeException

An exception thrown when we try to translate (or otherwise use) a JDBC type with no Rascal equivalent.

data RuntimeException  
= unsupportedJDBCType(JDBCType jdbcType)
;

function jdbc2RascalType

Get the Rascal type (as a symbol) for the given JDBC type

Symbol jdbc2RascalType(array())

Symbol jdbc2RascalType(bigInt())

Symbol jdbc2RascalType(binary())

Symbol jdbc2RascalType(bit())

Symbol jdbc2RascalType(blob())

Symbol jdbc2RascalType(boolean())

Symbol jdbc2RascalType(char())

Symbol jdbc2RascalType(clob())

Symbol jdbc2RascalType(dataLink())

Symbol jdbc2RascalType(date())

Symbol jdbc2RascalType(decimal())

Symbol jdbc2RascalType(distinct())

Symbol jdbc2RascalType(double())

Symbol jdbc2RascalType(float())

Symbol jdbc2RascalType(integer())

Symbol jdbc2RascalType(javaObject())

Symbol jdbc2RascalType(longNVarChar())

Symbol jdbc2RascalType(longVarBinary())

Symbol jdbc2RascalType(longVarChar())

Symbol jdbc2RascalType(nChar())

Symbol jdbc2RascalType(nClob())

Symbol jdbc2RascalType(JDBCType::null())

Symbol jdbc2RascalType(numeric())

Symbol jdbc2RascalType(nVarChar())

Symbol jdbc2RascalType(other())

Symbol jdbc2RascalType(JDBCType::\real())

Symbol jdbc2RascalType(ref())

Symbol jdbc2RascalType(rowId())

Symbol jdbc2RascalType(smallInt())

Symbol jdbc2RascalType(sqlXML())

Symbol jdbc2RascalType(struct())

Symbol jdbc2RascalType(time())

Symbol jdbc2RascalType(timeStamp())

Symbol jdbc2RascalType(tinyInt())

Symbol jdbc2RascalType(varBinary())

Symbol jdbc2RascalType(varChar())

data Nullable

Represents values which may or may not be null.

data Nullable[&T]  
= null()
| notnull(&T item)
;

function loadTable

Load the contents of a table. This will turn the contents into a set, which by its nature will remove any duplicates and discard any order. To maintain duplicates, or the order inherent in the table, use loadTableOrdered instead.

set[&T] loadTable(type[&T] resType, Connection connection, str tableName)

function loadTable

Load the contents of a table. This will turn the contents into a set, which by its nature will remove any duplicates and discard any order. To maintain duplicates, or the order inherent in the table, use loadTableOrdered instead. This versions uses no type information, meaning that it returns a set of values.

set[value] loadTable(Connection connection, str tableName)

function loadTableOrdered

Load the contents of a table. This maintains order and duplicates, but does not provide access to the relational operations provided by loadTable.

list[&T] loadTableOrdered(type[&T] resType, Connection connection, str tableName)

function loadTableOrdered

Load the contents of a table. This maintains order and duplicates, but does not provide access to the relational operations provided by loadTable. Also, with no type information, this version returns a list of values.

list[value] loadTableOrdered(Connection connection, str tableName)

function allTableSchemas

The JDBC tables schema should be given as: jdbctables+connect-string where connect-string is the database-specific information needed to connect, encoded as a URI, for instance: jdbctables+mysql://localhost/bugs?user=my_user_name&password=my_password

str allTableSchemas(str moduleName, loc uri)

function tableSchema

str tableSchema(str moduleName, loc uri)