mybatis框架在操作數(shù)據(jù)的時候,離不開SqlSession接口實例類的作用??梢哉fSqlSession接口實例是開發(fā)過程中打交道最多的一個類。即是DefaultSqlSession類。如果筆者記得沒有錯的話,早期是沒有什么getMapper方法的。增刪改查各志有對應的方法進行操作。雖然現(xiàn)在改進了很多,但是也保留了很多。我們依舊可以看到類似于selectList這樣子的方法。源碼的例子里面就可以找到。如下
SqlSession session = sqlMapper.openSession(TransactionIsolationLevel.SERIALIZABLE); try { List<Author> authors = session.selectList("org.apache.ibatis.domain.blog.mappers.AuthorMapper.selectAllAuthors"); assertEquals(2, authors.size()); } finally { session.close();
當然從某種意義上來講,寫起有一點煩。但是不可否認他的功能的確存在。這也是筆者為什么比較喜歡用動態(tài)代理來進行數(shù)據(jù)上的操作。至少可觀性上筆者認為比較好吧。
不管是哪一種數(shù)據(jù)上的操作都離不開SqlSession接口實例。所以深入查看qlSession接口實例就顯得相當?shù)闹匾?。筆者選擇了DefaultSqlSession類的selectList方法作為入口點進行切入。代碼如下。
1 public <E> List<E> selectList(String statement, Object parameter, RowBounds rowBounds) { 2