pro.chenggang.project.reactive.mybatis.support.r2dbc.ReactiveSqlSession Maven / Gradle / Ivy
package pro.chenggang.project.reactive.mybatis.support.r2dbc;
import io.r2dbc.spi.IsolationLevel;
import org.apache.ibatis.session.RowBounds;
import pro.chenggang.project.reactive.mybatis.support.r2dbc.delegate.R2dbcMybatisConfiguration;
import reactor.core.publisher.Flux;
import reactor.core.publisher.Mono;
/**
* The interface Reactive sql session.
*
* @author Gang Cheng
* @version 1.0.0
*/
public interface ReactiveSqlSession {
/**
* set auto commit
*
* @param autoCommit the auto commit
* @return current ReactiveSqlSession
*/
ReactiveSqlSession setAutoCommit(boolean autoCommit);
/**
* set isolation level
*
* @param isolationLevel the isolation level
* @return current ReactiveSqlSession
*/
ReactiveSqlSession setIsolationLevel(IsolationLevel isolationLevel);
/**
* set transaction or not
*
* @param usingTransactionSupport the using transaction support
* @return current ReactiveSqlSession
*/
ReactiveSqlSession usingTransaction(boolean usingTransactionSupport);
/**
* Retrieve a single row mapped from the statement key.
*
* @param the returned object type
* @param statement the statement
* @return Mapped object
*/
default Mono selectOne(String statement) {
return selectOne(statement, null);
}
/**
* Retrieve a single row mapped from the statement key and parameter.
*
* @param the returned object type
* @param statement Unique identifier matching the statement to use.
* @param parameter A parameter object to pass to the statement.
* @return Mapped object
*/
Mono selectOne(String statement, Object parameter);
/**
* Retrieve many mapped objects from the statement key.
*
* @param the returned list element type
* @param statement Unique identifier matching the statement to use.
* @return List of mapped object
*/
default Flux selectList(String statement) {
return selectList(statement, null);
}
/**
* Retrieve many mapped objects from the statement key and parameter.
*
* @param the returned list element type
* @param statement Unique identifier matching the statement to use.
* @param parameter A parameter object to pass to the statement.
* @return List of mapped object
*/
default Flux selectList(String statement, Object parameter) {
return selectList(statement, parameter, RowBounds.DEFAULT);
}
/**
* Retrieve many mapped objects from the statement key and parameter,
* within the specified row bounds.
*
* @param the returned list element type
* @param statement Unique identifier matching the statement to use.
* @param parameter A parameter object to pass to the statement.
* @param rowBounds Bounds to limit object retrieval
* @return List of mapped object
*/
Flux selectList(String statement, Object parameter, RowBounds rowBounds);
/**
* Execute an insert statement.
*
* @param statement Unique identifier matching the statement to execute.
* @return int The number of rows affected by the insert.
*/
default Mono insert(String statement) {
return insert(statement, null);
}
/**
* Execute an insert statement with the given parameter object. Any generated
* autoincrement values or selectKey entries will modify the given parameter
* object properties. Only the number of rows affected will be returned.
*
* @param statement Unique identifier matching the statement to execute.
* @param parameter A parameter object to pass to the statement.
* @return int The number of rows affected by the insert.
*/
Mono insert(String statement, Object parameter);
/**
* Execute an update statement. The number of rows affected will be returned.
*
* @param statement Unique identifier matching the statement to execute.
* @return int The number of rows affected by the update.
*/
default Mono update(String statement) {
return update(statement, null);
}
/**
* Execute an update statement. The number of rows affected will be returned.
*
* @param statement Unique identifier matching the statement to execute.
* @param parameter A parameter object to pass to the statement.
* @return int The number of rows affected by the update.
*/
Mono update(String statement, Object parameter);
/**
* Execute a delete statement. The number of rows affected will be returned.
*
* @param statement Unique identifier matching the statement to execute.
* @return int The number of rows affected by the delete.
*/
default Mono delete(String statement) {
return delete(statement, null);
}
/**
* Execute a delete statement. The number of rows affected will be returned.
*
* @param statement Unique identifier matching the statement to execute.
* @param parameter A parameter object to pass to the statement.
* @return int The number of rows affected by the delete.
*/
Mono delete(String statement, Object parameter);
/**
* Perform commits database connection.
* Note that database connection will not be committed if no updates/deletes/inserts were called.
* To force the commit call {@link ReactiveSqlSession#commit(boolean)}
*
* @return mono Void
*/
default Mono commit() {
return commit(false);
}
/**
* Perform commits database connection.
*
* @param force forces connection commit
* @return mono
*/
Mono commit(boolean force);
/**
* Perform rollback database connection .
* Note that database connection will not be rolled back if no updates/deletes/inserts were called.
* To force the rollback call {@link ReactiveSqlSession#rollback(boolean)}
*
* @return mono
*/
default Mono rollback() {
return rollback(false);
}
/**
* Discards pending batch statements and rolls database connection back.
* Note that database connection will not be rolled back if no updates/deletes/inserts were called.
*
* @param force forces connection rollback
* @return mono
*/
Mono rollback(boolean force);
/**
* close session
*
* @return mono
*/
Mono close();
/**
* Retrieves current configuration.
*
* @return R2dbcMybatisConfiguration configuration
*/
R2dbcMybatisConfiguration getConfiguration();
/**
* Retrieves a mapper.
*
* @param the mapper type
* @param type Mapper interface class
* @return a mapper bound to this SqlSession
*/
T getMapper(Class type);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy