1.Mybatis简介
1.1什么是Mybatis
MyBatis 是一款优秀的持久层框架。它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。
如何获得mybatis?
Maven仓库
<dependency>
<groupId>org.mybatis
</groupId>
<artifactId>mybatis
</artifactId>
<version>x.x.x
</version>
</dependency>
Github: https://github.com/mybatis/mybatis-3
Mybatis官方文档: http://www.mybatis.org/mybatis-3/zh/index.html
1.2持久化
数据持久化
持久化就是将程序的数据在持久状态和瞬时状态转化的过程内存:断电即失数据库(JDBC) IO文件持久化
1.3持久层
Dao层 Service层 Controller层…
完成持久化工作的代码块层界限十分明显
1.4为什么需要Mybatis
帮助程序员将数据存入到数据库中方便传统的JDBC太复杂了,简化框架,自动化。不用Mybatis也可以。更容易上手,技术没有高低之分,只有使用这个技术的人有高低之别Mybatis的优点:简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件就可以了,易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。提供xml标签,支持编写动态sql。
2.第一个Mybatis程序
思路流程:搭建环境–>导入Mybatis—>编写代码—>测试
1.创建数据库
CREATE DATABASE `mybatis`;
USE `mybatis`;
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
`id` int(20) NOT NULL,
`name` varchar(30) DEFAULT NULL,
`pwd` varchar(30) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into `user`(`id`,`name`,`pwd`) values (1,'小明','123456'),(2,'张三','abcdef'),(3,'李四','987654');
2.导入MyBatis相关 jar 包
<dependencies>
<dependency>
<groupId>mysql
</groupId>
<artifactId>mysql-connector-java
</artifactId>
<version>5.1.47
</version>
</dependency>
<dependency>
<groupId>org.mybatis
</groupId>
<artifactId>mybatis
</artifactId>
<version>3.5.2
</version>
</dependency>
<dependency>
<groupId>junit
</groupId>
<artifactId>junit
</artifactId>
<version>4.12
</version>
<scope>test
</scope>
</dependency>
</dependencies>
3.编写MyBatis核心配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf8"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>
<mappers>
</mappers>
</configuration>
idea连接mysql报错,Server returns invalid timezone. Need to set ‘serverTimezone’ property.
错误原因:时区问题,MySQL驱动默认UTC时区。
解决方法:https://blog.csdn.net/liuqiker/article/details/102455077
4.编写Mybatis工具类
import org
.apache
.ibatis
.io
.Resources
;
import org
.apache
.ibatis
.session
.SqlSession
;
import org
.apache
.ibatis
.session
.SqlSessionFactory
;
import org
.apache
.ibatis
.session
.SqlSessionFactoryBuilder
;
import java
.io
.IOException
;
import java
.io
.InputStream
;
public class MybatisUtils {
private static SqlSessionFactory sqlSessionFactory
;
static {
try {
String resource
= "mybatis-config.xml";
InputStream inputStream
= Resources
.getResourceAsStream(resource
);
sqlSessionFactory
= new SqlSessionFactoryBuilder().build(inputStream
);
} catch (IOException e
) {
e
.printStackTrace();
}
}
public static SqlSession
getSession(){
return sqlSessionFactory
.openSession();
}
}
5.创建实体类
public class User {
private int id
;
private String name
;
private String pwd
;
}