clean history

This commit is contained in:
Looly
2019-08-14 10:02:32 +08:00
commit 6b011af032
1215 changed files with 159913 additions and 0 deletions

View File

@@ -0,0 +1,113 @@
package cn.hutool.db.dialect;
import java.io.Serializable;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import cn.hutool.db.Entity;
import cn.hutool.db.sql.Query;
import cn.hutool.db.sql.Wrapper;
/**
* SQL方言不同的数据库由于在某些SQL上有所区别故为每种数据库配置不同的方言。<br>
* 由于不同数据库间SQL语句的差异导致无法统一拼接SQL<br>
* Dialect接口旨在根据不同的数据库使用不同的方言实现类来拼接对应的SQL并将SQL和参数放入PreparedStatement中
*
* @author loolly
*
*/
public interface Dialect extends Serializable{
/**
* @return 包装器
*/
Wrapper getWrapper();
/**
* 设置包装器
*
* @param wrapper 包装器
*/
void setWrapper(Wrapper wrapper);
// -------------------------------------------- Execute
/**
* 构建用于插入的PreparedStatement
*
* @param conn 数据库连接对象
* @param entity 数据实体类(包含表名)
* @return PreparedStatement
* @throws SQLException SQL执行异常
*/
PreparedStatement psForInsert(Connection conn, Entity entity) throws SQLException;
/**
* 构建用于批量插入的PreparedStatement
*
* @param conn 数据库连接对象
* @param entities 数据实体,实体的结构必须全部一致,否则插入结果将不可预知
* @return PreparedStatement
* @throws SQLException SQL执行异常
*/
PreparedStatement psForInsertBatch(Connection conn, Entity... entities) throws SQLException;
/**
* 构建用于删除的PreparedStatement
*
* @param conn 数据库连接对象
* @param query 查找条件(包含表名)
* @return PreparedStatement
* @throws SQLException SQL执行异常
*/
PreparedStatement psForDelete(Connection conn, Query query) throws SQLException;
/**
* 构建用于更新的PreparedStatement
*
* @param conn 数据库连接对象
* @param entity 数据实体类(包含表名)
* @param query 查找条件(包含表名)
* @return PreparedStatement
* @throws SQLException SQL执行异常
*/
PreparedStatement psForUpdate(Connection conn, Entity entity, Query query) throws SQLException;
// -------------------------------------------- Query
/**
* 构建用于获取多条记录的PreparedStatement
*
* @param conn 数据库连接对象
* @param query 查询条件(包含表名)
* @return PreparedStatement
* @throws SQLException SQL执行异常
*/
PreparedStatement psForFind(Connection conn, Query query) throws SQLException;
/**
* 构建用于分页查询的PreparedStatement
*
* @param conn 数据库连接对象
* @param query 查询条件(包含表名)
* @return PreparedStatement
* @throws SQLException SQL执行异常
*/
PreparedStatement psForPage(Connection conn, Query query) throws SQLException;
/**
* 构建用于查询行数的PreparedStatement
*
* @param conn 数据库连接对象
* @param query 查询条件(包含表名)
* @return PreparedStatement
* @throws SQLException SQL执行异常
*/
PreparedStatement psForCount(Connection conn, Query query) throws SQLException;
/**
* 方言名
*
* @return 方言名
*/
DialectName dialectName();
}