File tree 1 file changed +9
-9
lines changed
docs/system-design/framework/mybatis
1 file changed +9
-9
lines changed Original file line number Diff line number Diff line change @@ -197,14 +197,14 @@ public V get(Object key) {
197
197
198
198
举例:下面 join 查询出来 6 条记录,一、二列是 Teacher 对象列,第三列为 Student 对象列,MyBatis 去重复处理后,结果为 1 个老师 6 个学生,而不是 6 个老师 6 个学生。
199
199
200
- t_id t_name s_id
201
-
202
- | 1 | teacher | 38 |
203
- | 1 | teacher | 39 |
204
- | 1 | teacher | 40 |
205
- | 1 | teacher | 41 |
206
- | 1 | teacher | 42 |
207
- | 1 | teacher | 43 |
200
+ | t_id | t_name | s_id |
201
+ | ---- | ------- | ---- |
202
+ | 1 | teacher | 38 |
203
+ | 1 | teacher | 39 |
204
+ | 1 | teacher | 40 |
205
+ | 1 | teacher | 41 |
206
+ | 1 | teacher | 42 |
207
+ | 1 | teacher | 43 |
208
208
209
209
#### 10、MyBatis 是否支持延迟加载?如果支持,它的实现原理是什么?
210
210
@@ -238,7 +238,7 @@ public V get(Object key) {
238
238
239
239
** ` SimpleExecutor ` :** 每执行一次 update 或 select,就开启一个 Statement 对象,用完立刻关闭 Statement 对象。
240
240
241
- ** `` ReuseExecutor`:** 执行 update 或 select,以 sql 作为 key 查找 Statement 对象,存在就使用,不存在就创建,用完后,不关闭 Statement 对象,而是放置于 Map<String, Statement>内,供下一次使用。简言之,就是重复使用 Statement 对象。
241
+ ** ` ReuseExecutor ` :** 执行 update 或 select,以 sql 作为 key 查找 Statement 对象,存在就使用,不存在就创建,用完后,不关闭 Statement 对象,而是放置于 Map<String, Statement>内,供下一次使用。简言之,就是重复使用 Statement 对象。
242
242
243
243
** ` BatchExecutor ` :** 执行 update(没有 select,JDBC 批处理不支持 select),将所有 sql 都添加到批处理中(addBatch()),等待统一执行(executeBatch()),它缓存了多个 Statement 对象,每个 Statement 对象都是 addBatch()完毕后,等待逐一执行 executeBatch()批处理。与 JDBC 批处理相同。
244
244
You can’t perform that action at this time.
0 commit comments