|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object com.informatica.powercenter.sdk.mapfwk.core.Table com.informatica.powercenter.sdk.mapfwk.core.Transformation com.informatica.powercenter.sdk.mapfwk.core.SQLTransformation
public class SQLTransformation
The class StoredProcTransformation
extents
Transformation
.
This class implements the logic for SQL Transformation. The following information needs to be provided to the constructor. 1. Is the transformation in QueryMode 2. The Database type (Use the static variables used in SQLTransformation class. 3. Is the connection Static 4. Is the connection Object provided - This is considered only if the Connection is NOT static. Though the constructor takes a vector of InputSets as argument, currently SQLTransformations support only a single InputSet and thus only the first element of the Vector is used for the transformation. SQLTransformation consists of 2 GroupSets, SQLInputs and SQLOutputs. Depending on the combination the options given in the constructor, the following ports are created automatically when the object is created. If isQueryMode is true, then SQLError is created in SQLOutputs GroupSet. Else ScriptName is created in SQLInputs and ScriptResult and ScriptError are created in SQLOutputs. If isStaticConnection is true, then no ports are created. If isConnectionObjectProvided is true, then LogicalConnectionObject is created in SQLInputs. Else ConnectString, DBUser, DBPassword,CodePage, AdvancedOptions are created in SQLInputs If the InputSet or the tranform fields in the vector passed has any INPUT_OUTPUT fields, then they are split into an INPUT field with the same name and an OUTPUT field with an "_output" appended to the field name.
For Further details see Transformation Guide.
The code snippet for the SQLTransformation is
//create a Stored Procedure Transformation using the constructor given below: Mapping mapping = ...; // mapping to which the transform should be added Vector inputSetObj = ...; // collection of InputSet objects Vector vTransformFields = ...; // collection of TransformField objects TransformationProperties props = ...; // properties SQLTransformation sqlProcTrans = new SQLTransformation( "SQLTrans", "SQLTrans", "This is SQL Transformation", "SQLTrans", mapping, inputSetObj,vTransformFields,true, SQLTransformation.DBTYPE_ORACLE, true,false,props); //apply the transformation OutputSet outputSet = sqlProcTrans.apply(); //get the first rowset as Stored Procedure always returns a RowSet RowSet outRowSet = (RowSet)outputSet.getRowSets().get(0);
Field Summary | |
---|---|
static java.lang.String |
ATTR_SQLT_PORT_ATTRIBUTE
TransformField atrribute type SQLT_PORT_ATTRIBUTE |
static java.lang.String |
ATTR_SQLT_PORT_NATIVE_TYPE
TransformField atrribute type SQLT_PORT_NATIVE_TYPE |
static int |
DBTYPE_DB2
This defines the DB2 database type. |
static int |
DBTYPE_INFORMIX
This defines the Informix database type. |
static int |
DBTYPE_MICROSOFT_SQL_SERVER
This defines the Microsoft SQL server database type. |
static int |
DBTYPE_ODBC
This defines the ODBC database type. |
static int |
DBTYPE_ORACLE
This defines the oracle database type. |
static int |
DBTYPE_SYBASE
This defines the Sybase database type. |
static int |
DBTYPE_TERADATA
This defines the Teradata database type. |
Fields inherited from class com.informatica.powercenter.sdk.mapfwk.core.Transformation |
---|
m_templateID, m_templateName, m_transformFieldAttr, sessionTransformInst |
Fields inherited from class com.informatica.powercenter.sdk.mapfwk.core.Table |
---|
m_bReusable, m_readOnly |
Constructor Summary | |
---|---|
SQLTransformation()
Default constructor. |
|
SQLTransformation(java.lang.String name,
java.lang.String busName,
java.lang.String desc,
java.lang.String instName)
This sets SQL transformation by default to Query mode with static connection and DBType as SQLTransformation.DBTYPE_ORACLE. |
|
SQLTransformation(java.lang.String name,
java.lang.String busName,
java.lang.String desc,
java.lang.String instName,
Mapping mapping,
java.util.Vector vInputSets,
java.util.Vector vTransformFields,
boolean isQueryMode,
int DBType,
boolean isStaticConnection,
boolean isConnectionObjectProvided,
TransformationProperties properties)
Initialise the Transformation with all the required fields. |
Method Summary | |
---|---|
OutputSet |
apply()
Apply the SQL transformation and get a OutputSet as output. |
int |
getDBType()
returns the DBType of currently set for this transformation |
java.lang.String |
getSQLQuery()
Returns the SQLQuery that is currently set in the transformation. |
void |
setDBType(int type)
Use the static variables defined in this class for setting the value. |
void |
setSQLQuery(java.lang.String query)
This field is set only if the transformation was initialised in query mode, i.e, only if isQueryMode is true. |
Methods inherited from class com.informatica.powercenter.sdk.mapfwk.core.Transformation |
---|
add, addInitProp, defaultDuplicateNameRemovalSchema, genOutputSet, getGroupSet, getInitProps, getMapping, getOutFields, getOutputSet, getProperties, getSessionTransformInstanceKeySet, getSessionTransformInstanceProperty, getTemplateID, getTemplateName, getTransContext, getTransformationFieldAttr, getTransformationType, getTransformGroup, setGroupSet, setGroupSet, setMapping, setOutFields, setOutputSet, setReusable, setSessionTransformInstanceProperty, setTemplateIDAndName, setTransContext, setTransformationFieldAttr, setTransformationType, setTransformGroup, standardizeString |
Methods inherited from class com.informatica.powercenter.sdk.mapfwk.core.Table |
---|
addField, addMetaExtension, getBusinessName, getDescription, getField, getFields, getInstanceName, getMetaExtensions, getName, getReferencedField, isReadOnly, isReusable, removeField, removeMetaExtension, setBusinessName, setDescription, setFields, setInstanceName, setMetaExtensions, setMetaExtensionValue, setName, setReadOnly |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final int DBTYPE_ORACLE
public static final int DBTYPE_DB2
public static final int DBTYPE_SYBASE
public static final int DBTYPE_INFORMIX
public static final int DBTYPE_MICROSOFT_SQL_SERVER
public static final int DBTYPE_TERADATA
public static final int DBTYPE_ODBC
public static final java.lang.String ATTR_SQLT_PORT_ATTRIBUTE
public static final java.lang.String ATTR_SQLT_PORT_NATIVE_TYPE
Constructor Detail |
---|
public SQLTransformation()
public SQLTransformation(java.lang.String name, java.lang.String busName, java.lang.String desc, java.lang.String instName)
name
- name of the tablebusName
- business namedesc
- descriptioninstName
- instance namepublic SQLTransformation(java.lang.String name, java.lang.String busName, java.lang.String desc, java.lang.String instName, Mapping mapping, java.util.Vector vInputSets, java.util.Vector vTransformFields, boolean isQueryMode, int DBType, boolean isStaticConnection, boolean isConnectionObjectProvided, TransformationProperties properties) throws InvalidTransformationException
name
- name of the tablebusName
- business namedesc
- descriptioninstName
- instance namemapping
- Mapping for this TransformationvInputSets
- Vector of InputSet objects. Currently since SQL transformation supports only single InputSet, only the first element is considered.vTransformFields
- Vector of transform field objects. These are added to the SQL transformation group sets depending on the type of port.isQueryMode
- Is the SQL transformation in query mode. If false, then it is in Script modeDBType
- Use the static variables defined in SQLTransformation class to initialise this. E.g SQLTransformation.DBTYPE_ORACLE.isStaticConnection
- Is the connection static. If false, then it is dynamic connection.isConnectionObjectProvided
- For dynamic connection, is the connection Object provided? If false, then it creates ports to receive Full Connection Informationproperties
- Properties object to set the properties of the transformation
InvalidTransformationException
Method Detail |
---|
public int getDBType()
public void setDBType(int type)
type
- Sets teh DB type for this transformation. This has to be set before the apply function is called.public java.lang.String getSQLQuery()
public void setSQLQuery(java.lang.String query)
query
- The query for the SQL transformationpublic OutputSet apply() throws InvalidTransformationException
InvalidTransformationException
- exception
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |