Mybatis中几个重要类】的更多相关文章

解决方式way1:resultMap (1)studentMapper.xml <!-- 当数据库的字段名 和 类的属性名 不一致的时候的解决方式:2种 way1--> <select id="selectOneNotPipeiWay1" resultMap="aaa" parameterType="int"> select * from student where id = #{id} </select> &…
从测试类入手,断点调试 找到实现类,进入到insert方法里面 这里是SqlSession的接口里面的方法. 我们需要找SqlSession的实现类. DefaultSqlSession 里面有两个insert方法,第一个insert执行的是第二个insert方法,德尔格insert方法又执行的是下面的update方法 delete最终执行的也是update方法 我们的update方法传了两个参数 所以他最终执行的是这里两个参数的 update再往后走就是executor.update方法.也就…
delete方法没有并SqlSession的delete方法,而是调用的Upadte方法. 在测试类这里加断点. 实际的方法体内也加断点 运行测试方法,选择debug的方式 走到断点这里.会看到factory是DefaultSqlSessionFactory session是DefaultSqlSession 找借口的实现类 选中SqlSession 选中SqlSession并鼠标右键---show Implementations 显示它的所有实现 然后就显示了两个.通过刚才的断点调试我们知道是…
就是自己写实现类的方式来开发 直接finish 把之前写的CRUD的代码复制到过来. 在把之前pom.xml里面的包的依赖也复制过来 复制到当前的pom.xml内 允许自动导入 以上步骤就是复制了一个完整的上一节的CRUD的工程 调整和改造 QueryVo删掉. 映射文件中.resultMap的内容并不需要.也删除掉. 这里也需要把resultMap改成resultType.并且值是完整的包的路径 实际的开发过程中用的都是代理dao的方式.所以这里只作为了解.选学的内容 实体类改成和数据表 内的…
继续运行testFindAll方法.把其他类的断点都删除掉. 只在这里加了断点,所以直接就跳转到这里了.RoutingStatementHandler里面的query方法 继续往下走,断点又回到了这里.delegate变成了一个叫做PrparedStatementHandler 找PrparedStatementHandler PrparedStatementHandler里面找到query方法.然后加断点. preparedStatement就是JDBC里面的对象.ps.execute不仅能执…
http://www.open-open.com/lib/view/open1363572227609.html…
update和上面的Insert代码基本是一样的,只需要修改这里, 测试Update的方法 删除 findById 测试方法 findByName 测试方法 findTotal…
再完善.saveUser的方法 测试保存的操作 报错了 SqlSession的insert的源码 我们在执行Insert的时候,并没有把user对象传过去 usersex改成sex 再次测试…
转自:http://ccchhhlll1988-163-com.iteye.com/blog/1420026 MyBatis中常用的类就要数SqlSessionFactoryBuilder.SqlSessionFactory.SqlSession.SqlMapper了.那么下面对他们的应用范围和生命周期进行一下说明: 1.SqlSessionFactoryBuilder:在应用中该类实例的主要作用是创建SqlSessionFactory实例,故任务完成后就可以消失了.因此该类实例的最佳应用范围和…
一个实体类对应一个数据表 一个属性对应一个字段 默认情况下类名和属性名都采用 “下划线转驼峰” 的命名方式.但具体采用什么样的命名方式并不重要(方式一致即可),在后面使用这些对象的时候,可以通过 resultMap 对数据库的类和类的属性配置映射关系. 在 Mybatis 中,关于数据库的字段和 Java 类型的对应关系,不需要刻意去记,但需要注意一个特殊的类型 byte[] ,该类型一般对应数据库中的 BLOB.LONGVARBINARY 以及一些和二进制流有关的字段类型. 在实体类中不要使用…