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

io.ebean.CallableSql Maven / Gradle / Ivy

There is a newer version: 15.8.1
Show newest version
package io.ebean;

import java.sql.CallableStatement;
import java.sql.SQLException;

/**
 * For making calls to stored procedures. Refer to the Ebean execute() method.
 * 

* Note that UpdateSql is designed for general DML sql and CallableSql is * designed for use with stored procedures. Also note that when using this in * batch mode the out parameters are not read. *

*

* Example 1: *

*
{@code
 *
 * String sql = "{call sp_order_mod(?,?)}";
 *
 * CallableSql cs = DB.createCallableSql(sql);
 * cs.setParameter(1, "turbo");
 * cs.registerOut(2, Types.INTEGER);
 *
 * DB.execute(cs);
 *
 * // read the out parameter
 * Integer returnValue = (Integer) cs.getObject(2);
 *
 * }
*

* Example 2:
* Includes batch mode, table modification information and label. Note that the * label is really only to help people reading the transaction logs to identify * the procedure called etc. *

* *
{@code
 *
 * String sql = "{call sp_insert_order(?,?)}";
 *
 * CallableSql cs = DB.createCallableSql(sql);
 *
 * // Inform Ebean this stored procedure inserts into the
 * // oe_order table and inserts + updates the oe_order_detail table.
 * // this is used to invalidate objects in the cache
 * cs.addModification("oe_order", true, false, false);
 * cs.addModification("oe_order_detail", true, true, false);
 *
 *
 * try (Transaction t = DB.beginTransaction()) {
 *
 *   // execute using JDBC batching 10 statements at a time
 *   t.setBatchMode(true);
 *   t.setBatchSize(10);
 *
 *   cs.setParameter(1, "Was");
 *   cs.setParameter(2, "Banana");
 *   DB.execute(cs);
 *
 *   cs.setParameter(1, "Here");
 *   cs.setParameter(2, "Kumera");
 *   DB.execute(cs);
 *
 *   cs.setParameter(1, "More");
 *   cs.setParameter(2, "Apple");
 *   DB.execute(cs);
 *
 *   // DB.externalModification("oe_order",true,false,false);
 *   // DB.externalModification("oe_order_detail",true,true,false);
 *   t.commit();
 *
 * }
 * }
* * @see SqlUpdate */ public interface CallableSql { /** * Return the label that is put into the transaction log. */ String getLabel(); /** * Set the label that is put in the transaction log. */ CallableSql setLabel(String label); /** * Return the statement execution timeout. */ int getTimeout(); /** * Return the callable sql. */ String getSql(); /** * Set the statement execution timeout. Zero implies unlimited time. *

* This is set to the underlying CallableStatement. *

*/ CallableSql setTimeout(int secs); /** * Set the callable sql. */ CallableSql setSql(String sql); /** * Bind a parameter that is bound as a IN parameter. *

* position starts at value 1 (not 0) to be consistent with CallableStatement. *

*

* This is designed so that you do not need to set params in index order. You * can set/register param 2 before param 1 etc. *

* * @param position the index position of the parameter. * @param value the value of the parameter. */ CallableSql bind(int position, Object value); /** * Bind a positioned parameter (same as bind method). * * @param position the index position of the parameter. * @param value the value of the parameter. */ CallableSql setParameter(int position, Object value); /** * Register an OUT parameter. *

* Note that position starts at value 1 (not 0) to be consistent with * CallableStatement. *

*

* This is designed so that you do not need to register params in index order. * You can set/register param 2 before param 1 etc. *

* * @param position the index position of the parameter (starts with 1). * @param type the jdbc type of the OUT parameter that will be read. */ CallableSql registerOut(int position, int type); /** * Return an OUT parameter value. *

* position starts at value 1 (not 0) to be consistent with CallableStatement. *

*

* This can only be called after the CallableSql has been executed. When run * in batch mode you effectively can't use this method. *

*/ Object getObject(int position); /** * You can extend this object and override this method for more advanced * stored procedure calls. This would be the case when ResultSets are returned * etc. */ boolean executeOverride(CallableStatement cstmt) throws SQLException; /** * Add table modification information to the TransactionEvent. *

* This would be similar to using the * DB.externalModification() method. It may be easier and make * more sense to set it here with the CallableSql. *

*

* For UpdateSql the table modification information is derived by parsing the * sql to determine the table name and whether it was an insert, update or * delete. *

*/ CallableSql addModification(String tableName, boolean inserts, boolean updates, boolean deletes); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy