All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.pivotal.gemfirexd.internal.iapi.sql.execute.RunTimeStatistics Maven / Gradle / Ivy

There is a newer version: 1.6.7
Show newest version
/*

   Derby - Class com.pivotal.gemfirexd.internal.iapi.sql.execute.RunTimeStatistics

   Licensed to the Apache Software Foundation (ASF) under one or more
   contributor license agreements.  See the NOTICE file distributed with
   this work for additional information regarding copyright ownership.
   The ASF licenses this file to you under the Apache License, Version 2.0
   (the "License"); you may not use this file except in compliance with
   the License.  You may obtain a copy of the License at

      http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.

 */

package com.pivotal.gemfirexd.internal.iapi.sql.execute;

import java.io.Serializable;

import java.sql.Time;
import java.sql.Timestamp;

/**
	
  * A RunTimeStatistics object is a representation of the query execution plan and run
  * time statistics for a java.sql.ResultSet.
  * 
  * A query execution plan is a tree
  * of execution nodes.  There are a number of possible node types.  Statistics 
  * are accumulated during execution at each node.  The types of statistics include
  * the amount of time spent in specific operations (if STATISTICS TIMING is SET ON),
  * the number of rows passed to the node by its child(ren) and the number of rows
  * returned by the node to its parent.  (The exact statistics are specific to each
  * node type.)
  * 

* RunTimeStatistics is most meaningful for DML statements (SELECT, INSERT, DELETE * and UPDATE). * */ public interface RunTimeStatistics { /** * Get the total compile time for the associated query in milliseconds. * Compile time can be divided into parse, bind, optimize and generate times. *

* 0 is returned if STATISTICS TIMING is not SET ON. * * @return The total compile time for the associated query in milliseconds. */ public long getCompileTimeInMillis(); /** * Get the parse time for the associated query in milliseconds. *

* 0 is returned if STATISTICS TIMING is not SET ON. * * @return The parse time for the associated query in milliseconds. */ public long getParseTimeInMillis(); /** * Get the bind time for the associated query in milliseconds. * * @return The bind time for the associated query in milliseconds. */ public long getBindTimeInMillis(); /** * Get the optimize time for the associated query in milliseconds. *

* 0 is returned if STATISTICS TIMING is not SET ON. * * @return The optimize time for the associated query in milliseconds. */ public long getOptimizeTimeInMillis(); /** * Get the generate time for the associated query in milliseconds. *

* 0 is returned if STATISTICS TIMING is not SET ON. * * @return The generate time for the associated query in milliseconds. */ public long getGenerateTimeInMillis(); /** * Get the execute time for the associated query in milliseconds. *

* 0 is returned if STATISTICS TIMING is not SET ON. * * @return The execute time for the associated query in milliseconds. */ public long getExecuteTimeInMillis(); /** * Get the timestamp for the beginning of query compilation. *

* A null is returned if STATISTICS TIMING is not SET ON. * * @return The timestamp for the beginning of query compilation. */ public Timestamp getBeginCompilationTimestamp(); /** * Get the timestamp for the end of query compilation. *

* A null is returned if STATISTICS TIMING is not SET ON. * * @return The timestamp for the end of query compilation. */ public Timestamp getEndCompilationTimestamp(); /** * Get the timestamp for the beginning of query execution. *

* A null is returned if STATISTICS TIMING is not SET ON. * * @return The timestamp for the beginning of query execution. */ public Timestamp getBeginExecutionTimestamp(); /** * Get the timestamp for the end of query execution. *

* A null is returned if STATISTICS TIMING is not SET ON. * * @return The timestamp for the end of query execution. */ public Timestamp getEndExecutionTimestamp(); /** * Get the name of the associated query or statement. * (This will be an internally generated name if the * user did not assign a name.) * * @return The name of the associated query or statement. */ public String getStatementName(); /** * Get the name of the Stored Prepared Statement used * for the statement. This method returns * a value only for EXECUTE STATEMENT statements; * otherwise, returns null. *

* Note that the name is returned in the schema.name * format (e.g. APP.MYSTMT). * * @return The Stored Prepared Statement name of * the associated statement, or null if it is not an EXECUTE * STATEMENT statement. */ public String getSPSName(); /** * Get the text for the associated query or statement. * * @return The text for the associated query or statement. */ public String getStatementText(); /** * Get a String representation of the execution plan * for the associated query or statement. * * @return The execution plan for the associated query or statement. */ public String getStatementExecutionPlanText(); /** * Get a String representation of the information on the nodes * relating to table and index scans from the execution plan for * the associated query or statement. * * @return The nodes relating to table and index scans * from the execution plan for the associated query or statement. */ public String getScanStatisticsText(); /** * Get a String representation of the information on the nodes * relating to table and index scans from the execution plan for * the associated query or statement for a particular table. *

* @param tableName The table for which user desires statistics. *

* @return The nodes relating to table and index scans * from the execution plan for the associated query or statement. */ public String getScanStatisticsText(String tableName); /** * Get the estimated row count for the number of rows returned * by the associated query or statement. * * @return The estimated number of rows returned by the associated * query or statement. */ public double getEstimatedRowCount(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy