前言
mybatis是一个十分容易学习和领会其设计初衷的持久层框架,它能够帮助我们对JDBC操作数据库的过程进行封装,使我们更加关注与sql本身(就是怎么写sql语句:D).
一、前期准备
1.1首先创建一下数据库的表
-- 1、删除 mybatisstudy 数据库(如果存在)
drop database if exists mybatisstudy;
-- 2、创建数据库 mybatisstudy 数据库
create database mybatisstudy charset utf8;
use mybatisstudy; -- 选择yonghedb数据库
-- 3、在 mybatisstudy 库中创建 employee 表
create table employee(
id int primary key auto_increment,
name varchar(50),
job varchar(50),
salary double
);
-- 4、往 employee 表中, 插入若干条记录
insert into employee values(null, '张三', '职业1', 3300);
insert into employee values(null, '李四', '职业2', 2800);
insert into employee values(null, '王五', '职业3', 3700);
1.2下载JAR包
1.2.1 mybatis的jar包
1.2.2 myslq连接驱动jar包
mysql驱动jar包版本为5.0.8,当你的mysql版本过高或过低时,需要调整本jar包版本
1.2.3 log4j的jar包
log4j 1.2.17版本的jar包,这个包的用处就是可以帮助我们打出运行日志,方便记录过程和查找问题
二、创建工程
new一个 JAVA project,起名叫mybatisstudy
然后新建一个文件夹,叫library,用于存放我们的jar包,并将刚刚上面准备的jar包存放到该目录下,然后将jar包引入到工程内
log4j需要一个配置文件才能够运行,否则将会报错所以我们在src目录下,new一个file名字叫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
然后,我们在src目录下新建一个文件sqlMapConfig.xml这个文件的名字是mybatis官方推荐命名(不这么命名也可以)。这个文件是用于封装JDBC操作的。
<?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">
<!-- MyBatis的全局配置文件 -->
<configuration >
<!-- 环境的配置,default就是与下面id相同的一组环境 -->
<environments default="envir01">
<environment id="envir01">
<!-- transactionManger里的 type 可以选择将事务交给JDBC来处理还是交给MANGED自己来处理,这里我们选择JDBC处理-->
<transactionManager type="JDBC"></transactionManager>
<!-- dataSource 里的type类型可以选择POOLED即使用连接池,和UNPOOLED不使用连接池-->
<dataSource type="POOLED">
<!-- 下面就是jdbc的驱动配置了-->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatisstudy?characterEncoding=utf-8"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
<!-- mappers 配置的是sql映射文件,我们先设定映射文件是放在了com.mybatisstudy.pojo目录下 -->
<mappers>
<mapper resource="com/mybatisstudy/pojo/EmpMapper.xml"/>
</mappers>
</configuration>
接下来我们创建一个java类,用于存放对象
package com.mybatisstudy.pojo;
public class Employee {
//以下的四个都是与我们数据库列名相同的属性
private String name;
private String job;
private double salary;
private Integer id;
//因为get和set有点长,这里自己生成吧
//toString方法也生成一下吧,就不写在这里了
}
然后我们写一下mapper文件,文件名叫EmployeeMapper.xml,内容为:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace是该文件的唯一辨识,用于在执行时查找到sql语句,方式为namespace+下方sqlId的方式拼接-->
<mapper namespace="com.mybatisstudy.pojo.EmployeeMapper">
<!-- 这个resultType就是返回值,如果需要返回的是对象,那么就指定对象类的位置,否则其他情况下不需要返回值-->
<select id="findAll" resultType="com.mybatisstudy.pojo.Employee">
<!-- sql语句在mybatis中可以加分号”;“也可以不加-->
select * from employee
</select>
<insert id="insert01">
insert into employee(name,job,salary) values('criss','king',20);
</insert>
<update id="update01">
update employee set name = 'criss00001' where name='criss'
</update>
</mapper>
接着创建一个测试类,TestMybatis
package com.mybtisstudy.test;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
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 org.junit.Test;
import com.mybatisstudy.pojo.Employee;
public class TestMybatis {
@Test
public void findAll() throws IOException {
//这里用于读取配置文件,
InputStream stream = Resources.getResourceAsStream("sqlMapConfig.xml");
//这里新建一个session
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(stream);
//开始session
SqlSession session = factory.openSession();
//指定sql语句位置
String sqlId = "com.mybatisstudy.pojo.EmployeeMapper.findAll";
//因为这里返回值是list所以我们选择selectList的方法,如果确定只有一个返回结果的话,那么方法就应该是
//select()
List<Employee> employee = session.selectList(sqlId);
//打印出所有结果
for (Employee employee2 : employee) {
System.out.println(employee2);
}
}
}
打印结果如下:
如果要做的不是查询数据库,而是其他操作(删,改,赠)的情况下,我们需要在方法中提交事务,即session.commit(),否则会出现事务不能提交,数据库没有记录该条信息的问题