Mybatis环境搭建
学习记录
第一步
:配置pom.xml,输入相关jar包坐标,maven工程会自动下载jar包,如果下载过慢可配置自己的中央maven库,添加一个阿里云镜像,添加阿里云镜像的方法。传送门:添加阿里云镜像。
<packaging>jar</packaging>
<dependencies>
//mybatis的主要jar包
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.5</version>
</dependency>
//连接MySQL的jar包
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
//日志打印jar包
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.12</version>
</dependency>
//单元测试jar包
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.10</version>
</dependency>
//有些人这后面两个是不需要的
<dependency>
<groupId>org.apache.ibatis</groupId>
<artifactId>ibatis-core</artifactId>
<version>3.0</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
第二步
:创建一个对应数据库中表数据的实体类以及该类的dao接口,mybatis通过调用dao接口的方法去执行想要执行的操作。
此处只用作举例.
实体类代码:
public class User {
private Integer id;
private String username;
private Date brithday;
private String sex;
private String address;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public Date getBrithday() {
return brithday;
}
public void setBrithday(Date brithday) {
this.brithday = brithday;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", brithday=" + brithday +
", sex='" + sex + '\'' +
", address='" + address + '\'' +
'}';
}
}
dao接口代码:
public interface UserDao {
/**
* 查询所有操作
* @return
*/
List<User> findAll();
}
第三步
配置mybatis,这里是主配置文件,用于连接MySQL数据库,以及dao接口的文件位置等信息。其他具体需要看情况进行配置。
创建一个.xml文件。
<?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的主配置文件 -->
<!-- mybatis环境搭建第三步 -->
<configuration>
<!-- 配置环境-->
<environments default="mysql">
<!-- 配置mysql环境-->
<environment id="mysql">
<!-- 配置事务的类型-->
<transactionManager type="JDBC"> </transactionManager>
<!-- 配置数据源(连接池)-->
<dataSource type="POOLED">
<!-- 配置连接数据库的4个基本信息-->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/essy?characterEncoding=utf8"/>
<property name="username" value="root"/>
<property name="password" value="123"/>
</dataSource>
</environment>
</environments>
<!-- 指定映射配置文件的位置,映射配置文件指的是每个dao独立的配置文件-->
<!-- mybatis的映射配置文件必须和dao接口的包结构相同,即若dao接口是三级目录配置文件也要是三级目录 -->
<mappers>
<mapper resource="com/yang/dao/UserDao.xml"/>
</mappers>
</configuration>
第四步
配置dao接口的配置文件。该文件是mybatis使用xml文件配置的方式才需要,如果使用注解开发,就不需要该文件。
开启mybatis注解支持,在第三步的配置文件中加上下面这段代码即可
<!-- 指定带有注解的dao接口所在位置 -->
<mappers>
<mapper class="com.itheima.dao.IUserDao"></mapper>
</mappers>
使用xml配置mybatis,需要给每个dao接口配置其相关文件。
<?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">
<mapper namespace="com.yang.dao.UserDao">
<!-- mybatis环境搭建第四步 -->
<!-- UserDao和UserMapper是一样的 -->
<!-- 配置查询所有-->
<!-- id必须是接口中的方法名-->
<select id="findAll" resultType="com.yang.domain.User">
select * from user
</select>
</mapper>
到此mybatis的使用xml配置的环境已经配置完成。下面是一个简单的测试类来测试是否能从数据库中获取到数据。
public class MybatisTest {
public static void main(String[] args) throws Exception {
//1.读取配置文件
InputStream in= Resources.getResourceAsStream("SqlMapConfig.xml");
//InputStream in = new FileInputStream("SqlMapConfig.xml"); // 相对路径,项目下的路径
//2.创建SqlSessionFactory工厂
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory=builder.build(in);
//3.使用工厂生产SqlSession对象
SqlSession session = factory.openSession();
//4.使用SqlSession创建Dao接口的代理对象
UserDao userDao = session.getMapper(UserDao.class);
//5.使用代理对象执行方法
List<User> users = userDao.findAll();
for(User user : users){
System.out.println(user);
}
//6.释放资源
session.close();
in.close();
}
}
此博客只做学习记录,不到位的地方请指出。