- 浏览: 984373 次
文章分类
- 全部博客 (428)
- Hadoop (2)
- HBase (1)
- ELK (1)
- ActiveMQ (13)
- Kafka (5)
- Redis (14)
- Dubbo (1)
- Memcached (5)
- Netty (56)
- Mina (34)
- NIO (51)
- JUC (53)
- Spring (13)
- Mybatis (17)
- MySQL (21)
- JDBC (12)
- C3P0 (5)
- Tomcat (13)
- SLF4J-log4j (9)
- P6Spy (4)
- Quartz (12)
- Zabbix (7)
- JAVA (9)
- Linux (15)
- HTML (9)
- Lucene (0)
- JS (2)
- WebService (1)
- Maven (4)
- Oracle&MSSQL (14)
- iText (11)
- Development Tools (8)
- UTILS (4)
- LIFE (8)
最新评论
-
Donald_Draper:
Donald_Draper 写道刘落落cici 写道能给我发一 ...
DatagramChannelImpl 解析三(多播) -
Donald_Draper:
刘落落cici 写道能给我发一份这个类的源码吗Datagram ...
DatagramChannelImpl 解析三(多播) -
lyfyouyun:
请问楼主,执行消息发送的时候,报错:Transport sch ...
ActiveMQ连接工厂、连接详解 -
ezlhq:
关于 PollArrayWrapper 状态含义猜测:参考 S ...
WindowsSelectorImpl解析一(FdMap,PollArrayWrapper) -
flyfeifei66:
打算使用xmemcache作为memcache的客户端,由于x ...
Memcached分布式客户端(Xmemcached)
在前文中,Mybatis使用教程中,有下面一段代码:
首先我们来看这一句
而sqlSessionFactory默认为DefaultSqlSessionFactory
从DefaultSqlSessionFactory的方法,我们可以看出openSession实际上,是通过
openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit)
其中ExecutorType为执行器类型,TransactionIsolationLevel为事务级别,autoCommit是否自动提交;
下面来看一下openSessionFromDataSource方法:
来看这一句
//根据environment获取事务工厂
再看这一句
//根据数据源,事务级别,是否自动提交,创建事务
//JdbcTransaction
事务看完,我们来看一下
//根据数据源,事务级别,是否自动提交,创建执行器
//Configuration
从上面configuration的创建执行器方法,可以看出执行器有BatchExecutor,ReuseExecutor,SimpleExecutor
根据执行器类型,创建执行器,如果缓存启用,则包装executor为CachingExecutor;
//BatchExecutor
//SimpleExecutor
//CachingExecutor
//BaseExecutor
现在回到DefaultSqlSessionFactory的方法过openSessionFromDataSource
//根据配置和executor构建DefaultSqlSession
//DefaultSqlSession
从DefaultSqlSession方法可以看出,查询则委托给executor的query,插入,更新,删除,则委托给executor的update;
总结:
DefaultSqlSessionFactory根据执行器类型,事务级别,是否提交等信息,来构建执行器Executor,然后根据执行器和configuration构建SqlSession,默认为DefaultSqlSession,从DefaultSqlSession的类信息方法来看,DefaultSqlSession的
查询则委托给executor的query,插入,更新,删除,则委托给executor的update,提交,回滚,清除缓存,刷新Statement,关闭SqlSession,都是委托给Executor的相应方法。下面一节我们来Executor。
//ExecutorType
public final class ExecutorType extends Enum
{
private ExecutorType(String s, int i)
{
super(s, i);
}
public static final ExecutorType SIMPLE;
public static final ExecutorType REUSE;
public static final ExecutorType BATCH;
static
{
SIMPLE = new ExecutorType("SIMPLE", 0);
REUSE = new ExecutorType("REUSE", 1);
BATCH = new ExecutorType("BATCH", 2);
$VALUES = (new ExecutorType[] {
SIMPLE, REUSE, BATCH
});
}
}
//TransactionIsolationLevel
public final class TransactionIsolationLevel extends Enum
{
public static TransactionIsolationLevel valueOf(String name)
{
return (TransactionIsolationLevel)Enum.valueOf(org/apache/ibatis/session/TransactionIsolationLevel, name);
}
private TransactionIsolationLevel(String s, int i, int level)
{
super(s, i);
this.level = level;
}
public int getLevel()
{
return level;
}
public static final TransactionIsolationLevel NONE;
public static final TransactionIsolationLevel READ_COMMITTED;
public static final TransactionIsolationLevel READ_UNCOMMITTED;
public static final TransactionIsolationLevel REPEATABLE_READ;
public static final TransactionIsolationLevel SERIALIZABLE;
private final int level;
private static final TransactionIsolationLevel $VALUES[];
static
{
NONE = new TransactionIsolationLevel("NONE", 0, 0);
READ_COMMITTED = new TransactionIsolationLevel("READ_COMMITTED", 1, 2);
READ_UNCOMMITTED = new TransactionIsolationLevel("READ_UNCOMMITTED", 2, 1);
REPEATABLE_READ = new TransactionIsolationLevel("REPEATABLE_READ", 3, 4);
SERIALIZABLE = new TransactionIsolationLevel("SERIALIZABLE", 4,;
$VALUES = (new TransactionIsolationLevel[] {
NONE, READ_COMMITTED, READ_UNCOMMITTED, REPEATABLE_READ, SERIALIZABLE
});
}
}
//Executor
public interface Executor
{
public abstract int update(MappedStatement mappedstatement, Object obj)
throws SQLException;
public abstract List query(MappedStatement mappedstatement, Object obj, RowBounds rowbounds, ResultHandler resulthandler, CacheKey cachekey, BoundSql boundsql)
throws SQLException;
public abstract List query(MappedStatement mappedstatement, Object obj, RowBounds rowbounds, ResultHandler resulthandler)
throws SQLException;
public abstract List flushStatements()
throws SQLException;
public abstract void commit(boolean flag)
throws SQLException;
public abstract void rollback(boolean flag)
throws SQLException;
public abstract CacheKey createCacheKey(MappedStatement mappedstatement, Object obj, RowBounds rowbounds, BoundSql boundsql);
public abstract boolean isCached(MappedStatement mappedstatement, CacheKey cachekey);
public abstract void clearLocalCache();
public abstract void deferLoad(MappedStatement mappedstatement, MetaObject metaobject, String s, CacheKey cachekey, Class class1);
public abstract Transaction getTransaction();
public abstract void close(boolean flag);
public abstract boolean isClosed();
public static final ResultHandler NO_RESULT_HANDLER = null;
}
SqlSession session = sqlSessionFactory.openSession(); try { User u1 = new User(); u1.setAge(12); u1.setName("donald"); session.insert("test.Dao.UserMapper.insert", u1); User u2 = session.selectOne("test.Dao.UserMapper.selectByPrimaryKey", u1.getId()); System.out.println("======u1:"+JsonUtil.toJson(u2)); User u3 = new User(); u3.setAge(30); u3.setName("jamel"); session.insert("test.Dao.UserMapper.insert", u3); User u4 = session.selectOne("test.Dao.UserMapper.selectByPrimaryKey", u3.getId()); System.out.println("======u3:"+JsonUtil.toJson(u4)); // session.flushStatements(); session.commit(); u3.setName("rain"); session.update("test.Dao.UserMapper.updateByPrimaryKeySelective", u3); // session.commit(); User u5 = session.selectOne("test.Dao.UserMapper.selectByPrimaryKey", u3.getId()); System.out.println("======cache-u3-name:"+u5.getName()); } catch(Exception e){ e.printStackTrace(); } finally { session.close(); }
首先我们来看这一句
SqlSession session = sqlSessionFactory.openSession();
而sqlSessionFactory默认为DefaultSqlSessionFactory
//DefaultSqlSessionFactory public class DefaultSqlSessionFactory implements SqlSessionFactory { public DefaultSqlSessionFactory(Configuration configuration) { this.configuration = configuration; } public SqlSession openSession() { return openSessionFromDataSource(configuration.getDefaultExecutorType(), null, false); } public SqlSession openSession(boolean autoCommit) { return openSessionFromDataSource(configuration.getDefaultExecutorType(), null, autoCommit); } public SqlSession openSession(ExecutorType execType) { return openSessionFromDataSource(execType, null, false); } public SqlSession openSession(TransactionIsolationLevel level) { return openSessionFromDataSource(configuration.getDefaultExecutorType(), level, false); } public SqlSession openSession(ExecutorType execType, TransactionIsolationLevel level) { return openSessionFromDataSource(execType, level, false); } public SqlSession openSession(ExecutorType execType, boolean autoCommit) { return openSessionFromDataSource(execType, null, autoCommit); } public SqlSession openSession(Connection connection) { return openSessionFromConnection(configuration.getDefaultExecutorType(), connection); } public SqlSession openSession(ExecutorType execType, Connection connection) { return openSessionFromConnection(execType, connection); } private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit) { // } private SqlSession openSessionFromConnection(ExecutorType execType, Connection connection) { } }
从DefaultSqlSessionFactory的方法,我们可以看出openSession实际上,是通过
openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit)
其中ExecutorType为执行器类型,TransactionIsolationLevel为事务级别,autoCommit是否自动提交;
下面来看一下openSessionFromDataSource方法:
private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit) { Transaction tx = null; DefaultSqlSession defaultsqlsession; try { //从configuration获取environment Environment environment = configuration.getEnvironment(); //根据environment获取事务工厂 TransactionFactory transactionFactory = getTransactionFactoryFromEnvironment(environment); //根据数据源,事务级别,是否自动提交,创建事务 tx = transactionFactory.newTransaction(environment.getDataSource(), level, autoCommit); //根据数据源,事务级别,是否自动提交,创建执行器 org.apache.ibatis.executor.Executor executor = configuration.newExecutor(tx, execType, autoCommit); //根据配置和executor构建DefaultSqlSession defaultsqlsession = new DefaultSqlSession(configuration, executor); } catch(Exception e) { closeTransaction(tx); throw ExceptionFactory.wrapException((new StringBuilder()).append("Error opening session. Cause: ").append(e).toString(), e); } }
来看这一句
//根据environment获取事务工厂
TransactionFactory transactionFactory = getTransactionFactoryFromEnvironment(environment); private TransactionFactory getTransactionFactoryFromEnvironment(Environment environment) { if(environment == null || environment.getTransactionFactory() == null) return new ManagedTransactionFactory(); else //从environment获取事务工厂,JdbcTransactionFactory或PooledDataSourceFactory return environment.getTransactionFactory(); }
再看这一句
//根据数据源,事务级别,是否自动提交,创建事务
tx = transactionFactory.newTransaction(environment.getDataSource(), level, autoCommit); //JdbcTransactionFactory public class JdbcTransactionFactory implements TransactionFactory { //根据数据源,事务级别,是否自动提交,创建事务 public Transaction newTransaction(DataSource ds, TransactionIsolationLevel level, boolean autoCommit) { return new JdbcTransaction(ds, level, autoCommit); } }
//JdbcTransaction
public class JdbcTransaction implements Transaction { protected Connection connection;//数据库连接 protected DataSource dataSource;//数据源 protected TransactionIsolationLevel level;//事务级别 protected boolean autoCommmit; public JdbcTransaction(DataSource ds, TransactionIsolationLevel desiredLevel, boolean desiredAutoCommit) { dataSource = ds; level = desiredLevel; autoCommmit = desiredAutoCommit; } //获取Connection public Connection getConnection() throws SQLException { if(connection == null) openConnection(); return connection; } //打开Connection protected void openConnection() throws SQLException { if(log.isDebugEnabled()) log.debug("Openning JDBC Connection"); connection = dataSource.getConnection(); if(level != null) //设置连接事务级别 connection.setTransactionIsolation(level.getLevel()); setDesiredAutoCommit(autoCommmit); } //提交事务 public void commit() throws SQLException { if(connection != null && !connection.getAutoCommit()) { if(log.isDebugEnabled()) log.debug((new StringBuilder()).append("Committing JDBC Connection [").append(connection).append("]").toString()); connection.commit(); } } //回滚事务 public void rollback() throws SQLException { if(connection != null && !connection.getAutoCommit()) { if(log.isDebugEnabled()) log.debug((new StringBuilder()).append("Rolling back JDBC Connection [").append(connection).append("]").toString()); connection.rollback(); } } //关闭事务 public void close() throws SQLException { if(connection != null) { resetAutoCommit(); if(log.isDebugEnabled()) log.debug((new StringBuilder()).append("Closing JDBC Connection [").append(connection).append("]").toString()); connection.close(); } } }
事务看完,我们来看一下
//根据数据源,事务级别,是否自动提交,创建执行器
org.apache.ibatis.executor.Executor executor = configuration.newExecutor(tx, execType, autoCommit);
//Configuration
public Executor newExecutor(Transaction transaction, ExecutorType executorType, boolean autoCommit) { executorType = executorType != null ? executorType : defaultExecutorType; executorType = executorType != null ? executorType : ExecutorType.SIMPLE; Executor executor; if(ExecutorType.BATCH == executorType) executor = new BatchExecutor(this, transaction); else if(ExecutorType.REUSE == executorType) executor = new ReuseExecutor(this, transaction); else executor = new SimpleExecutor(this, transaction); if(cacheEnabled) executor = new CachingExecutor(executor, autoCommit); //将执行器插入到拦截器链中 executor = (Executor)interceptorChain.pluginAll(executor); return executor; }
从上面configuration的创建执行器方法,可以看出执行器有BatchExecutor,ReuseExecutor,SimpleExecutor
根据执行器类型,创建执行器,如果缓存启用,则包装executor为CachingExecutor;
//BatchExecutor
public class BatchExecutor extends BaseExecutor { public static final int BATCH_UPDATE_RETURN_VALUE = -2147482646; private final List statementList = new ArrayList(); private final List batchResultList = new ArrayList(); private String currentSql; private MappedStatement currentStatement; public BatchExecutor(Configuration configuration, Transaction transaction) { super(configuration, transaction); } }
//SimpleExecutor
public class SimpleExecutor extends BaseExecutor { public SimpleExecutor(Configuration configuration, Transaction transaction) { super(configuration, transaction); } }
//CachingExecutor
public class CachingExecutor implements Executor { private Executor _flddelegate;//代理执行器 private boolean autoCommit; private TransactionalCacheManager tcm; private boolean dirty; public CachingExecutor(Executor delegate, boolean autoCommit) { tcm = new TransactionalCacheManager(); _flddelegate = delegate; this.autoCommit = autoCommit; } }
//BaseExecutor
public abstract class BaseExecutor implements Executor { private static final Log log = LogFactory.getLog(org/apache/ibatis/executor/BaseExecutor); protected Transaction transaction; protected ConcurrentLinkedQueue deferredLoads; protected PerpetualCache localCache; protected PerpetualCache localOutputParameterCache; protected Configuration configuration; protected int queryStack; private boolean closed; //构造BaseExecutor protected BaseExecutor(Configuration configuration, Transaction transaction) { queryStack = 0; this.transaction = transaction; deferredLoads = new ConcurrentLinkedQueue(); localCache = new PerpetualCache("LocalCache"); localOutputParameterCache = new PerpetualCache("LocalOutputParameterCache"); closed = false; this.configuration = configuration; } //获取Connection protected Connection getConnection(Log statementLog) throws SQLException { Connection connection = transaction.getConnection(); if(statementLog.isDebugEnabled()) return ConnectionLogger.newInstance(connection, statementLog); else return connection; } //提交 public void commit(boolean required) throws SQLException { if(closed) throw new ExecutorException("Cannot commit, transaction is already closed"); clearLocalCache(); flushStatements(); if(required) transaction.commit(); } public List flushStatements() throws SQLException { return flushStatements(false); } public List flushStatements(boolean isRollBack) throws SQLException { if(closed) throw new ExecutorException("Executor was closed."); else return doFlushStatements(isRollBack); } //待子类扩展 protected abstract List doFlushStatements(boolean flag) throws SQLException; //回滚 public void rollback(boolean required) throws SQLException { if(closed) break MISSING_BLOCK_LABEL_49; clearLocalCache(); flushStatements(true); if(required) transaction.rollback(); break MISSING_BLOCK_LABEL_49; Exception exception; exception; if(required) transaction.rollback(); throw exception; } //清除本地缓存 public void clearLocalCache() { if(!closed) { localCache.clear(); localOutputParameterCache.clear(); } } //更新 public int update(MappedStatement ms, Object parameter) throws SQLException { ErrorContext.instance().resource(ms.getResource()).activity("executing an update").object(ms.getId()); if(closed) { throw new ExecutorException("Executor was closed."); } else { //首先清除缓存 clearLocalCache(); //委托给doUpdate return doUpdate(ms, parameter); } } //带子类扩展 protected abstract int doUpdate(MappedStatement mappedstatement, Object obj) throws SQLException; //查询 public List query(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, CacheKey key, BoundSql boundSql) throws SQLException { ErrorContext.instance().resource(ms.getResource()).activity("executing a query").object(ms.getId()); if(closed) throw new ExecutorException("Executor was closed."); if(queryStack == 0 && ms.isFlushCacheRequired()) //如果queryStack为0,且需要刷新缓存,则清除本地缓存 clearLocalCache(); List list; queryStack++; list = resultHandler != null ? null : (List)localCache.getObject(key); if(list != null) //从本地获取查询结果 handleLocallyCachedOutputParameters(ms, key, parameter, boundSql); else //从数据库查询结果 list = queryFromDatabase(ms, parameter, rowBounds, resultHandler, key, boundSql); queryStack--; break MISSING_BLOCK_LABEL_152; Exception exception; exception; queryStack--; throw exception; if(queryStack == 0) { DeferredLoad deferredLoad; for(Iterator i$ = deferredLoads.iterator(); i$.hasNext(); deferredLoad.load()) deferredLoad = (DeferredLoad)i$.next(); deferredLoads.clear(); if(configuration.getLocalCacheScope() == LocalCacheScope.STATEMENT) clearLocalCache(); } return list; } //从数据库查询结果 private List queryFromDatabase(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, CacheKey key, BoundSql boundSql) throws SQLException { localCache.putObject(key, ExecutionPlaceholder.EXECUTION_PLACEHOLDER); //将查询委托给doQuery List list = doQuery(ms, parameter, rowBounds, resultHandler, boundSql); localCache.removeObject(key); break MISSING_BLOCK_LABEL_53; Exception exception; exception; localCache.removeObject(key); throw exception; localCache.putObject(key, list); if(ms.getStatementType() == StatementType.CALLABLE) localOutputParameterCache.putObject(key, parameter); return list; } //待子类扩展 protected abstract List doQuery(MappedStatement mappedstatement, Object obj, RowBounds rowbounds, ResultHandler resulthandler, BoundSql boundsql) throws SQLException; }
现在回到DefaultSqlSessionFactory的方法过openSessionFromDataSource
//根据配置和executor构建DefaultSqlSession
defaultsqlsession = new DefaultSqlSession(configuration, executor);
//DefaultSqlSession
public class DefaultSqlSession implements SqlSession { private Configuration configuration; private Executor executor; private boolean dirty; public DefaultSqlSession(Configuration configuration, Executor executor) { this.configuration = configuration; this.executor = executor; dirty = false; } //查询 public Object selectOne(String statement) { return selectOne(statement, null); } public Object selectOne(String statement, Object parameter) { List list = selectList(statement, parameter); if(list.size() == 1) return list.get(0); if(list.size() > 1) throw new TooManyResultsException((new StringBuilder()).append("Expected one result (or null) to be returned by selectOne(), but found: ").append(list.size()).toString()); else return null; } public List selectList(String statement) { return selectList(statement, null); } public List selectList(String statement, Object parameter) { return selectList(statement, parameter, RowBounds.DEFAULT); } public List selectList(String statement, Object parameter, RowBounds rowBounds) { List list; try { org.apache.ibatis.mapping.MappedStatement ms = configuration.getMappedStatement(statement); //调用executor的查询方法 List result = executor.query(ms, wrapCollection(parameter), rowBounds, Executor.NO_RESULT_HANDLER); list = result; } } //插入 public int insert(String statement) { return insert(statement, null); } public int insert(String statement, Object parameter) { //委托给update方法 return update(statement, parameter); } public int update(String statement) { return update(statement, null); } public int update(String statement, Object parameter) { int i; try { dirty = true; org.apache.ibatis.mapping.MappedStatement ms = configuration.getMappedStatement(statement); //委托给executor的update i = executor.update(ms, wrapCollection(parameter)); } } //删除 public int delete(String statement) { //委托给update return update(statement, null); } public int delete(String statement, Object parameter) { return update(statement, parameter); } //提交 public void commit() { commit(false); } public void commit(boolean force) { try { //委托executor的commit executor.commit(isCommitOrRollbackRequired(force)); dirty = false; } } //回滚 public void rollback() { rollback(false); } public void rollback(boolean force) { try { //委托executor的rollback executor.rollback(isCommitOrRollbackRequired(force)); dirty = false; } } //清除缓存 public void clearCache() { ////委托executor的clearLocalCache executor.clearLocalCache(); } //刷新Statements public List flushStatements() { List list; try { //委托executor的flushStatements list = executor.flushStatements(); } } //关闭SqlSession public void close() { //委托executor的close executor.close(isCommitOrRollbackRequired(false)); dirty = false; } }
从DefaultSqlSession方法可以看出,查询则委托给executor的query,插入,更新,删除,则委托给executor的update;
总结:
DefaultSqlSessionFactory根据执行器类型,事务级别,是否提交等信息,来构建执行器Executor,然后根据执行器和configuration构建SqlSession,默认为DefaultSqlSession,从DefaultSqlSession的类信息方法来看,DefaultSqlSession的
查询则委托给executor的query,插入,更新,删除,则委托给executor的update,提交,回滚,清除缓存,刷新Statement,关闭SqlSession,都是委托给Executor的相应方法。下面一节我们来Executor。
//ExecutorType
public final class ExecutorType extends Enum
{
private ExecutorType(String s, int i)
{
super(s, i);
}
public static final ExecutorType SIMPLE;
public static final ExecutorType REUSE;
public static final ExecutorType BATCH;
static
{
SIMPLE = new ExecutorType("SIMPLE", 0);
REUSE = new ExecutorType("REUSE", 1);
BATCH = new ExecutorType("BATCH", 2);
$VALUES = (new ExecutorType[] {
SIMPLE, REUSE, BATCH
});
}
}
//TransactionIsolationLevel
public final class TransactionIsolationLevel extends Enum
{
public static TransactionIsolationLevel valueOf(String name)
{
return (TransactionIsolationLevel)Enum.valueOf(org/apache/ibatis/session/TransactionIsolationLevel, name);
}
private TransactionIsolationLevel(String s, int i, int level)
{
super(s, i);
this.level = level;
}
public int getLevel()
{
return level;
}
public static final TransactionIsolationLevel NONE;
public static final TransactionIsolationLevel READ_COMMITTED;
public static final TransactionIsolationLevel READ_UNCOMMITTED;
public static final TransactionIsolationLevel REPEATABLE_READ;
public static final TransactionIsolationLevel SERIALIZABLE;
private final int level;
private static final TransactionIsolationLevel $VALUES[];
static
{
NONE = new TransactionIsolationLevel("NONE", 0, 0);
READ_COMMITTED = new TransactionIsolationLevel("READ_COMMITTED", 1, 2);
READ_UNCOMMITTED = new TransactionIsolationLevel("READ_UNCOMMITTED", 2, 1);
REPEATABLE_READ = new TransactionIsolationLevel("REPEATABLE_READ", 3, 4);
SERIALIZABLE = new TransactionIsolationLevel("SERIALIZABLE", 4,;
$VALUES = (new TransactionIsolationLevel[] {
NONE, READ_COMMITTED, READ_UNCOMMITTED, REPEATABLE_READ, SERIALIZABLE
});
}
}
//Executor
public interface Executor
{
public abstract int update(MappedStatement mappedstatement, Object obj)
throws SQLException;
public abstract List query(MappedStatement mappedstatement, Object obj, RowBounds rowbounds, ResultHandler resulthandler, CacheKey cachekey, BoundSql boundsql)
throws SQLException;
public abstract List query(MappedStatement mappedstatement, Object obj, RowBounds rowbounds, ResultHandler resulthandler)
throws SQLException;
public abstract List flushStatements()
throws SQLException;
public abstract void commit(boolean flag)
throws SQLException;
public abstract void rollback(boolean flag)
throws SQLException;
public abstract CacheKey createCacheKey(MappedStatement mappedstatement, Object obj, RowBounds rowbounds, BoundSql boundsql);
public abstract boolean isCached(MappedStatement mappedstatement, CacheKey cachekey);
public abstract void clearLocalCache();
public abstract void deferLoad(MappedStatement mappedstatement, MetaObject metaobject, String s, CacheKey cachekey, Class class1);
public abstract Transaction getTransaction();
public abstract void close(boolean flag);
public abstract boolean isClosed();
public static final ResultHandler NO_RESULT_HANDLER = null;
}
发表评论
-
Mybatis缓存实现
2016-12-07 10:36 983SqlSessionFactory初始化:http://don ... -
DefaultSqlSession第三讲-事务提交,回滚,关闭SqlSession,清除缓存
2016-11-20 11:07 5714上面两篇讲过query和update及flushStateme ... -
DefaultSqlSession第二讲-更新,刷新Statement
2016-11-20 11:06 635上一篇文章中,我们讲到DefaultSqlSession的查询 ... -
DefaultSqlSession第一讲query解析
2016-11-20 11:06 1631上一篇文章:我们说过DefaultSqlSession,Def ... -
Mybatis的Reflector解析
2016-11-18 12:53 2164Mybatis的MetaObject解析:http://don ... -
Mybatis的MetaObject解析
2016-11-18 11:40 9583SqlSessionFactory初始化:http://don ... -
mybatis 动态标签语句的解析(BoundSql)
2016-10-30 09:48 5765SqlSessionFactory初始化:http://don ... -
Mybatis的Environment解析详解
2016-10-29 18:28 1998SqlSessionFactory初始化:http://don ... -
Mybatis 解析Mapper(class)
2016-10-26 11:44 3364SqlSessionFactory初始化:http://don ... -
Mybatis加载解析Mapper(xml)文件第二讲
2016-10-25 21:30 4804SqlSessionFactory初始化:http://don ... -
Mybatis加载解析Mapper(xml)文件第一讲
2016-10-25 16:51 6198SqlSessionFactory初始化:http://don ... -
SqlSessionFactory初始化
2016-10-20 15:38 2460mybatis 使用教程:http://donald-drap ... -
mybatis 使用教程
2016-10-14 09:03 914Myeclispe下mybatis generator的使 ... -
Spring+Mybatis多数据源的实现
2016-09-21 18:15 3095浅谈Spring事务隔离级别:http://www.cnblo ... -
mybaitis CDATA 防止字符被解析
2016-08-17 18:45 727在使用mybatis 时我们sql是写在xml 映射文件中,如 ... -
Myeclispe下mybatis generator的使用
2016-07-05 18:05 1379准备:下载附件包解压到myeclispe的dropins文件夹 ...
相关推荐
使用MyBatis访问数据库需要首先创建一个SqlSessionFactory,然后使用SqlSessionFactory创建一个SqlSession,最后使用SqlSession执行数据库访问操作。MyBatis提供了多种数据库访问方式,包括INSERT、UPDATE、DELETE、...
### MyBatis解析配置文件的工具类知识点解析 在Java Web开发中,MyBatis作为一款优秀的持久层框架,能够极大地简化数据访问层(DAO)的编码工作,提高开发效率。本文将详细介绍一个用于初始化MyBatis环境并提供获取...
SqlSessionFactory是MyBatis的主要入口点,它负责创建SqlSession对象,而SqlSession则用于执行数据库操作。Mapper接口或Mapper XML文件定义了具体的SQL查询和结果映射,它们与MyBatis的Executor执行器配合,完成对...
《MyBatis 3.x 源码深度解析与最佳实践》是一份深入探讨MyBatis框架核心原理和实践技巧的资源。MyBatis作为Java领域广泛应用的持久层框架,以其简洁灵活的特性深受开发者喜爱。这份资料旨在帮助开发者更好地理解和...
"基于IOC容器实现管理mybatis过程解析" IOC容器是Inversion of Control的缩写,指的是控制反转容器。在软件设计中,控制反转是一种设计原则,它将对象的控制权从对象本身转移到外部容器中,从而实现了对象之间的松...
创建SqlSession的过程涉及到MyBatis的配置解析和会话构建,其创建过程大致可以分为以下几个步骤: 1. 利用Resources读取Mybatis的主配置文件 首先,使用MyBatis提供的Resources工具类的getResourceAsReader静态方法...
本文将基于给定的"Mybatis--SQL解析流程图",详细介绍Mybatis中SQL解析的具体流程,包括SqlSession与Mapper动态代理对象的获取步骤,旨在帮助读者深入理解Mybatis的工作机制。 #### 二、创建SqlSessionFactory 在...
总结起来,MyBatis源码分析涵盖了从配置加载到数据库操作的全过程,涉及到了配置解析、SQL执行、结果映射等多个关键环节,以及Executor、StatementHandler等核心组件。通过深入学习MyBatis的源码,开发者不仅可以...
第 6 章: 介绍 MyBatis 的解析和运行原理, 我们将了解到 SqlSession 的构建方法, 以 及其四大对象是如何工作的。 第 7 章: 在第 6 章的基础上着重介绍 MyBatis 的插件, 这里我们将学习插件的设计原 理, 以及...
1. **MyBatis入门**:安装和配置MyBatis,创建第一个Mapper和SqlSession。 2. **XML配置与注解**:两种声明SQL语句的方式,理解动态SQL的使用。 3. **Mapper接口**:通过接口定义SQL操作,利用MyBatis的自动映射功能...
2. **SqlSessionFactory**:这是MyBatis的主要接口,它创建SqlSession实例,管理数据库会话。SqlSessionFactory是线程安全的,可以在应用的整个生命周期中保持单例。 3. **SqlSession**:代表与数据库的一次会话,...
1. **配置解析**:MyBatis的配置文件(mybatis-config.xml)被解析成Configration对象,这个对象包含了所有的全局配置信息,如数据源、事务管理器、Mappers等。解析过程主要由XMLConfigBuilder类完成。 2. **...
MyBatis-Spring 是 MyBatis 与 Spring 框架的整合,它为 MyBatis 的 SqlSessionFactory 和 SqlSession 提供了 Spring 的管理方式。MyBatis-Spring 可以帮助开发者无缝地将 MyBatis 集成到 Spring 应用中,使得事务...
### MyBatis源码解析——由阿里巴巴P7架构师纯手工打造 #### 一、前言 在现代软件开发过程中,持久层框架如MyBatis因其简单易用、灵活高效的特点而受到广泛欢迎。作为一款优秀的Java持久层框架,MyBatis通过SQL...
MyBatis作为一个流行的持久化框架,其源码是开放的,允许开发者深入了解框架...MyBatis使用XML解析器解析映射文件,将SQL语句和数据库操作转化为Java对象。 4. SQL执行: 当执行SQL操作时,MyBatis会将映射文件。。。
- `XMLConfigBuilder`解析`mybatis-config.xml`,构建`Configuration`对象,这个对象包含了myBatis的所有配置信息。 - `XMLMapperBuilder`处理`mapper.xml`文件,根据`mapper`元素构建`MapperRegistry`,并为每个`...
通过对MyBatis源码的学习,我们可以了解到MyBatis如何解析配置,如何构建SQL,如何处理参数和结果,以及如何利用缓存提高性能。这对于理解和优化MyBatis的应用,甚至开发自己的持久层框架都有极大的帮助。在阅读源码...
`mybatis-3.2.2`则是MyBatis的核心库,包含了MyBatis的主要功能,如SQL映射文件解析、动态SQL生成等。 描述中提到的“这两个包经常出现版本兼容性问题”,这是因为在不同的版本之间,API可能会有所改变,或者某个...
一、MyBatis源码解析 MyBatis的源码主要由SqlSessionFactoryBuilder、SqlSessionFactory、SqlSession和Mapper接口等核心组件构成。SqlSessionFactoryBuilder用于创建SqlSessionFactory,它是MyBatis的核心工厂类。...