/*
* JBoss, Home of Professional Open Source.
*
* See the LEGAL.txt file distributed with this work for information regarding copyright ownership and licensing.
*
* See the AUTHORS.txt file distributed with this work for a full listing of individual contributors.
*/
package org.teiid.designer.metamodels.transformation;
import org.eclipse.emf.ecore.EObject;
/**
* <!-- begin-user-doc --> A representation of the model object '<em><b>Sql Alias</b></em>'. <!-- end-user-doc -->
* <p>
* The following features are supported:
* <ul>
* <li>{@link org.teiid.designer.metamodels.transformation.SqlAlias#getAlias <em>Alias</em>}</li>
* <li>{@link org.teiid.designer.metamodels.transformation.SqlAlias#getAliasedObject <em>Aliased Object</em>}</li>
* <li>{@link org.teiid.designer.metamodels.transformation.SqlAlias#getSqlTransformation <em>Sql Transformation</em>}</li>
* </ul>
* </p>
*
* @see org.teiid.designer.metamodels.transformation.TransformationPackage#getSqlAlias()
* @model
* @generated
*
* @since 8.0
*/
public interface SqlAlias extends EObject {
/**
* Returns the value of the '<em><b>Alias</b></em>' attribute. <!-- begin-user-doc -->
* <p>
* If the meaning of the '<em>Alias</em>' attribute isn't clear, there really should be more of a description here...
* </p>
* <!-- end-user-doc -->
*
* @return the value of the '<em>Alias</em>' attribute.
* @see #setAlias(String)
* @see org.teiid.designer.metamodels.transformation.TransformationPackage#getSqlAlias_Alias()
* @model
* @generated
*/
String getAlias();
/**
* Sets the value of the '{@link org.teiid.designer.metamodels.transformation.SqlAlias#getAlias <em>Alias</em>}' attribute. <!--
* begin-user-doc --> <!-- end-user-doc -->
*
* @param value the new value of the '<em>Alias</em>' attribute.
* @see #getAlias()
* @generated
*/
void setAlias( String value );
/**
* Returns the value of the '<em><b>Aliased Object</b></em>' reference. <!-- begin-user-doc -->
* <p>
* If the meaning of the '<em>Aliased Object</em>' reference list isn't clear, there really should be more of a description
* here...
* </p>
* <!-- end-user-doc -->
*
* @return the value of the '<em>Aliased Object</em>' reference.
* @see #setAliasedObject(EObject)
* @see org.teiid.designer.metamodels.transformation.TransformationPackage#getSqlAlias_AliasedObject()
* @model required="true"
* @generated
*/
EObject getAliasedObject();
/**
* Sets the value of the '{@link org.teiid.designer.metamodels.transformation.SqlAlias#getAliasedObject <em>Aliased Object</em>}'
* reference. <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @param value the new value of the '<em>Aliased Object</em>' reference.
* @see #getAliasedObject()
* @generated
*/
void setAliasedObject( EObject value );
/**
* Returns the value of the '<em><b>Sql Transformation</b></em>' container reference. It is bidirectional and its opposite is
* '{@link org.teiid.designer.metamodels.transformation.SqlTransformation#getAliases <em>Aliases</em>}'. <!-- begin-user-doc -->
* <p>
* If the meaning of the '<em>Sql Transformation</em>' container reference isn't clear, there really should be more of a
* description here...
* </p>
* <!-- end-user-doc -->
*
* @return the value of the '<em>Sql Transformation</em>' container reference.
* @see #setSqlTransformation(SqlTransformation)
* @see org.teiid.designer.metamodels.transformation.TransformationPackage#getSqlAlias_SqlTransformation()
* @see org.teiid.designer.metamodels.transformation.SqlTransformation#getAliases
* @model opposite="aliases"
* @generated
*/
SqlTransformation getSqlTransformation();
/**
* Sets the value of the '{@link org.teiid.designer.metamodels.transformation.SqlAlias#getSqlTransformation
* <em>Sql Transformation</em>}' container reference. <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @param value the new value of the '<em>Sql Transformation</em>' container reference.
* @see #getSqlTransformation()
* @generated
*/
void setSqlTransformation( SqlTransformation value );
} // SqlAlias