com.espertech.esper.client.soda.SQLStream Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of esper Show documentation
Show all versions of esper Show documentation
Complex event processing and event series analysis component
/**************************************************************************************
* Copyright (C) 2006-2015 EsperTech Inc. All rights reserved. *
* http://www.espertech.com/esper *
* http://www.espertech.com *
* ---------------------------------------------------------------------------------- *
* The software in this package is published under the terms of the GPL license *
* a copy of which has been included with this distribution in the license.txt file. *
**************************************************************************************/
package com.espertech.esper.client.soda;
import java.io.StringWriter;
/**
* An SQL stream that polls via SQL for events via join.
*/
public class SQLStream extends Stream
{
private String databaseName;
private String sqlWithSubsParams;
private String optionalMetadataSQL;
private static final long serialVersionUID = 2606529559298987982L;
/**
* Ctor.
*/
public SQLStream() {
}
/**
* Creates a new SQL-based stream.
* @param databaseName is the database name to poll
* @param sqlWithSubsParams is the SQL to use
* @return stream
*/
public static SQLStream create(String databaseName, String sqlWithSubsParams)
{
return new SQLStream(databaseName, sqlWithSubsParams, null, null);
}
/**
* Creates a new SQL-based stream.
* @param databaseName is the database name to poll
* @param sqlWithSubsParams is the SQL to use
* @param optStreamName is the as-name of the stream
* @return stream
*/
public static SQLStream create(String databaseName, String sqlWithSubsParams, String optStreamName)
{
return new SQLStream(databaseName, sqlWithSubsParams, optStreamName, null);
}
/**
* Creates a new SQL-based stream.
* @param databaseName is the database name to poll
* @param sqlWithSubsParams is the SQL to use
* @param optStreamName is the as-name of the stream
* @param optionalMetadataSQL optional SQL delivering metadata of statement
* @return stream
*/
public static SQLStream create(String databaseName, String sqlWithSubsParams, String optStreamName, String optionalMetadataSQL)
{
return new SQLStream(databaseName, sqlWithSubsParams, optStreamName, optionalMetadataSQL);
}
/**
* Ctor.
* @param databaseName is the database name to poll
* @param sqlWithSubsParams is the SQL to use
* @param optStreamName is the optional as-name of the stream, or null if unnamed
* @param optionalMetadataSQL optional SQL delivering metadata of statement
*/
public SQLStream(String databaseName, String sqlWithSubsParams, String optStreamName, String optionalMetadataSQL)
{
super(optStreamName);
this.databaseName = databaseName;
this.sqlWithSubsParams = sqlWithSubsParams;
this.optionalMetadataSQL = optionalMetadataSQL;
}
/**
* Returns the database name.
* @return database name
*/
public String getDatabaseName()
{
return databaseName;
}
/**
* Sets the database name.
* @param databaseName database name
*/
public void setDatabaseName(String databaseName)
{
this.databaseName = databaseName;
}
/**
* Returns the SQL with optional substitution parameters in the SQL.
* @return SQL
*/
public String getSqlWithSubsParams()
{
return sqlWithSubsParams;
}
/**
* Sets the SQL with optional substitution parameters in the SQL.
* @param sqlWithSubsParams SQL set set
*/
public void setSqlWithSubsParams(String sqlWithSubsParams)
{
this.sqlWithSubsParams = sqlWithSubsParams;
}
/**
* Returns the metadata SQL if any.
* @return metadata SQL
*/
public String getOptionalMetadataSQL()
{
return optionalMetadataSQL;
}
/**
* Sets metadata SQL.
* @param optionalMetadataSQL is the SQL to fire to obtain metadata from, or null if disabled
*/
public void setOptionalMetadataSQL(String optionalMetadataSQL)
{
this.optionalMetadataSQL = optionalMetadataSQL;
}
public void toEPLStream(StringWriter writer, EPStatementFormatter formatter)
{
writer.write("sql:");
writer.write(databaseName);
writer.write("[\"");
writer.write(sqlWithSubsParams);
writer.write("\"]");
}
public void toEPLStreamType(StringWriter writer)
{
writer.write("sql:");
writer.write(databaseName);
writer.write("[..]");
}
public void toEPLStreamOptions(StringWriter writer)
{
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy