Class FBProcedureCall

java.lang.Object
org.firebirdsql.jdbc.FBProcedureCall

@InternalApi @NullMarked public class FBProcedureCall extends Object
Represents procedure call.

This class is internal API of Jaybird. Future versions may radically change, move, or make inaccessible this type.

  • Constructor Details

    • FBProcedureCall

      public FBProcedureCall()
  • Method Details

    • copyOf

      public static FBProcedureCall copyOf(FBProcedureCall source)
    • getName

      public @Nullable String getName()
      Get the name of the procedure to be called.
      Returns:
      The procedure name
    • setName

      public void setName(String name)
      Set the name of the procedure to be called.
      Parameters:
      name - The name of the procedure
    • getInputParam

      public FBProcedureParam getInputParam(int index)
      Get input parameter by the specified index.
      Parameters:
      index - index for which parameter has to be returned, first index is 1
      Returns:
      instance of FBProcedureParam.
    • getOutputParam

      public FBProcedureParam getOutputParam(int index)
      Get the output parameter at the specified index.
      Parameters:
      index - The index of the parameter, first index is 1
      Returns:
      The parameter at the given index
    • mapOutParamIndexToPosition

      public int mapOutParamIndexToPosition(int index) throws SQLException
      Map output parameter index to a column number of the corresponding result set.
      Parameters:
      index - index to map
      Returns:
      mapped column number or index if no output parameter with the specified index is found
      Throws:
      SQLException - in current implementation: never, throws clause retained for compatibility and possibly future uses
    • getInputParams

      public List<@Nullable FBProcedureParam> getInputParams()
      Get the list of input parameters for this procedure call.
      Returns:
      A list of all input parameters
    • getOutputParams

      public List<@Nullable FBProcedureParam> getOutputParams()
      Get a list of output parameters for this procedure call.
      Returns:
      A list of all output parameters
    • addInputParam

      public void addInputParam(FBProcedureParam param)
      Add an input parameter to this procedure call.
      Parameters:
      param - The parameter to be added
    • addOutputParam

      public void addOutputParam(FBProcedureParam param)
      Add an output parameter to this procedure call.
      Parameters:
      param - The parameter to be added
    • addParam

      public FBProcedureParam addParam(int position, String param)
      Add call parameter. This method adds new parameter to the procedure call and tries to automatically place the parameter into the right collection if it contains a hint whether it is input or output parameter.
      Parameters:
      position - position of the parameter in the procedure call.
      param - contents of the parameter.
      Returns:
      instance of the FBProcedureParam that was created to represent this parameter.
    • registerOutParam

      public void registerOutParam(int index, int type) throws SQLException
      Register output parameter. This method marks parameter with the specified index as output. Parameters marked as output cannot be used as input parameters.
      Parameters:
      index - index of the parameter to mark as output.
      type - SQL type of the parameter.
      Throws:
      SQLException - if something went wrong.
    • getSQL

      public String getSQL(boolean select) throws SQLException
      Get native SQL for the specified procedure call.
      Returns:
      native SQL that can be executed by the database server.
      Throws:
      SQLException
    • checkParameters

      public void checkParameters() throws SQLException
      Checks if all parameters have been set.
      Throws:
      SQLException - When some parameters don't have values, and are not registered as an out parameter.
    • equals

      public boolean equals(Object obj)
      Check if obj is equal to this instance.
      Overrides:
      equals in class Object
      Returns:
      true iff obj is instance of this class representing the same procedure with the same parameters.
    • hashCode

      public int hashCode()
      Overrides:
      hashCode in class Object