大家好,我是IT修真院深圳分院第5期学员,一枚正直善良的JAVA程序员。
今天给大家分享一下,修真院官网JAVA任务1中,深度思考部分的知识点——Spring中的IOC是什么意思,为什么要用IOC而不是New来创建实例?
一、背景介绍
1、Mybatis是现在比较常用的持久层框架,使用起来比较方便,而且功能也相对强大,实现方法分别是基于注解和基于映射文件。但是当需要操作的实体类较多时,逐个编写基于注解或基于映射文件的CRUD耗时长且容易出错,重复这种操作对个人的能力提升也没有帮助,使用Mybatis Generator不仅可以保证基本CRUD的编写准确,还能节省大量的编码时间,是一个值得推荐使用的生成代码的方法
2、MyBatis Generator (MBG) 是一个Mybatis的代码生成器,它可以帮助我们根据数据库中表的设计生成对应的xml Mapper文件,接口以及实体类(也就是我们可以借助该类来进行简单的CRUD操作),这样就避免了我们每使用到一张表的数据就需要手动去创建对应的类和xml文件,这就帮我们节约了大量的时间去开发和业务逻辑有关的功能,但是如果对联合查询和存储过程我们仍然需要手写SQL和对象。下面我主要介绍MBG的相关知识点以及操作方法。
二、知识剖析
实现MBG的方式
1.使用命令行生成(了解)
2.使用maven插件进行生成(常用)
两种方式使用的generator.xml文件内的配置都是一样的,第一种需要用命令行加载jar包,第二种则需要用编辑器配置pom.xml
使用mybatis generator进行代码生成的操作步骤
第一步:准备数据库、表
第二步:3个依赖和1个插件
mybatis.jar
mybatis-generator-core.jar
mysql-connector-java.jar
mybatis-generator-maven-plugin
第三步:编写配置文件generatorConfig.xml
a.配置数据库连接地址及账号密码
b.生成的Model类存放位置
c.生成的映射文件存放位置
d.指定要生成的表(命名规范)
代码生成的映射文件提供了几种常用的CRUD操作
1.insert()
2.insertSelective()
3.updateByPrimaryKeySelective()
4.updateByPrimaryKey()
5.selectByPrimaryKey()
6.deleteByPrimaryKey()
mybatis-generator的运行过程
连接数据库——》从数据库的表中获取字段——》依据字段生成mapper文件、dao、实体类
命令行生成
三、常见问题
只能逆向生成mapper.xml文件吗,可否生成annotation的mapper呢?
4.解决方案
将javaclientgenerator参数中的TYPE值由XMLMAPPER改为ANNOTATEDMAPPER即可
五、编码实战
六、扩展思考
七、参考文献
1.官方文档:http://mbg.cndocs.ml/configreference/xmlconfig.html
2.CSDN博客:http://blog.csdn.net/tolcf/article/details/50835165
八、更多讨论
问:如果数据库是下划线命名,生成的实体类是什么命名?
答:驼峰法
问:除了那几个生成的基本语句,可以通过mybatis generator自定义SQL语句吗?
答: 能,但是操作比较麻烦,涉及的知识点比较多
问:生成的xml文件中resultmap能自动生成吗
答:能
PPT:PPT
感谢大家观看
今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~
技能树.IT修真院
“我们相信人人都可以成为一个工程师,现在开始,找个师兄,带你入门,掌控自己学习的节奏,学习的路上不再迷茫”。
这里是技能树.IT修真院,成千上万的师兄在这里找到了自己的学习路线,学习透明化,成长可见化,师兄1对1免费指导。快来与我一起学习吧~
作者:东
链接://www.greatytc.com/p/338d445e7332
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。