系列文章目录
前言
一、mybatis-简介
结合代码更容易理解,第一次看不懂学习了代码之后,回头再看一遍就很容易理解了
 MyBatis 本是apache的一个开源项目iBatis,
 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis,实质上Mybatis对ibatis进行一些改进。
MyBatis是一个优秀的持久层框架,它对jdbc的操作数据库的过程进行封装,
 使开发者只需要关注 SQL 本身,
 而不需要花费精力去处理例如注册驱动、
 创建connection、创建statement、手动设置参数、结果集检索等jdbc繁杂的过程代码。
小结:对jdbc的封装框架有哪些:Hibernate,dbutils,jdbcTemplate[spring],mybatis
原理:Mybatis通过xml或注解的方式将要执行的各种statement(statement、preparedStatemnt、CallableStatement)配置起来,并通过java对象和statement中的sql进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射成java对象并返回
JDBC程序代码分析:

 JDBC代码存在的问题或者说缺点
数据库连接频繁开启和关闭,会严重影响数据库的性能。
 代码中存在硬编码,分别是数据库部分的硬编码和SQL执行部分的硬编码。
硬编码就是什么都在你的程序代码里面写死了,你想稍微修改一下效果,都得修改你的代码。
 做的比较灵活的就是,你想稍微修改得到一点其他的效果,不用修改你的代码,使用比较常用的配置文件来实现!
MyBatis框架的核心
1、mybatis配置文件,包括Mybatis全局配置文件和Mybatis映射文件,其中全局配置文件配置了数据源、事务等信息;映射文件配置了SQL执行相关的 信息。
 2、mybatis通过读取配置文件信息(全局配置文件和映射文件),构造出SqlSessionFactory,即会话工厂。
 3、通过SqlSessionFactory,可以创建SqlSession即会话。Mybatis是通过SqlSession来操作数据库的。
 4、SqlSession本身不能直接操作数据库,它是通过底层的Executor执行器接口来操作数据库的。Executor接口有两个实现类,一个是普通执行器,一个是缓存执行器(默认)。
 5、Executor执行器要处理的SQL信息是封装到一个底层对象MappedStatement中。该对象包括:SQL语句、输入参数映射信息、输出结果集映射信息。其中输入参数和输出结果的映射类型包括HashMap集合对象、POJO对象类型。
注意:POJO对象就是简单对象,简单对象就是model,里面就是属性、getset或者构造器,toString方法等,除此之外没有任何功能
二、环境准备
下载MyBatis
 mybaits的代码由github.com管理,
下载地址:
 https://github.com/mybatis/mybatis-3/releases

 我们要用的是这个压缩包


 我已经下载好了,直接可以用


注意,因为要操作数据库,数据库驱动的jar包也是少不了的
新建数据库


 执行


 接下来就是 创建项目



 注意,简单的项目不是一个web项目
 接下来就是导jar包



在IDEA下全部要导入的jar包就是这些

添加log4j.properties
 Mybatis使用的日志包是log4j的,所以需要添加log4j.properties

# Global logging configuration
log4j.rootLogger=DEBUG, stdout
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

 如果日志要写入文件也是可以的,只是需要稍微修改一下文件里面的内容(再加个File)
这样环境搭建就搭建好了,下一篇文章,一起来使用
总结
这一路走下来我们会发现,java用的很多东西都是apache的
                










