首先准备sql语句
CREATE DATABASE eesy_mybatis; DROP DATABASE ecif; CREATE TABLE `user` ( `id` INT(11) NOT NULL AUTO_INCREMENT, `username` VARCHAR(32) NOT NULL COMMENT '用户名称', `birthday` DATETIME DEFAULT NULL COMMENT '生日', `sex` CHAR(1) DEFAULT NULL COMMENT '性别', `address` VARCHAR(256) DEFAULT NULL COMMENT '地址', PRIMARY KEY (`id`) ) ENGINE=INNODB DEFAULT CHARSET=utf8; INSERT INTO `user`(`id`,`username`,`birthday`,`sex`,`address`) VALUES (41,'老王','2018-02-27 17:47:08','男','北京'),(42,'小二王','2018-03-02 15:09:37','女','北京金燕龙'),(43,'小二王','2018-03-04 11:34:34','女','北京金燕龙'),(45,'传智播客','2018-03-04 12:04:06','男','北京金燕龙'),(46,'老王','2018-03-07 17:37:26','男','北京'),(48,'小马宝莉','2018-03-08 11:44:00','女','北京修正'); • 15
1添加 Mybatis3.4.5 的坐标,和其他的依赖关系
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com</groupId> <artifactId>CURD</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.5</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.12</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.6</version> </dependency> </dependencies> </project>
2.创建一个User类
里面的属性和sql语句定义的要一致,这是因为MyBatis的工作原理,涉及到映射器
映射器的主要作用就是将 SQL 查询到的结果映射为一个 POJO,或者将 POJO 的数据插入到数据库中,并定义一些关于缓存等的重要内容。
package com.domain; import java.io.Serializable; import java.util.Date; public class User implements Serializable{ private Integer id; private String username; private String address; private String sex; private Date brithday; 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 String getAddress() { return address; } public void setAddress(String address) { this.address = address; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } public Date getBrithday() { return brithday; } public void setBrithday(Date brithday) { this.brithday = brithday; } @Override public String toString() { return "User{" + "id=" + id + ", username='" + username + '\'' + ", address='" + address + '\'' + ", sex='" + sex + '\'' + ", brithday=" + brithday + '}'; } }
3.编写持久层接口 IUserDao,注意这是个接口
注意,开发只是一个接口,而不是一个实现类。初学者可能会产生一个很大的疑问,那就是接口不是不能运行吗?
是的,接口不能直接运行。MyBatis 运用了动态代理技术使得接口能运行起来,入门阶段只要懂得 MyBatis 会为这个接口生成一个代理对象,代理对象会去处理相关的逻辑即可。
package com.dao; import com.domain.User; import java.util.List; //用户的持久层接口 public interface IUserDao { List<User> findall(); }
4.编写持久层接口的映射文件 IUserDao.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确定该方法在哪个dao接口中--> <mapper namespace="com.dao.IUserDao"> <!--id来确定是具体哪个方法--> <!--id+namespace确定了一个固定的方法--> <!--resulttype表示要封装到那里去--> <!--里面写的是sql语句--> <select id="findall" resultType="com.domain.User"> SELECT * FROM user; </select> </mapper>
5.编写 SqlMapConfig.xml 配置文件
在resources中编写
<?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="mysql"> <environment id="mysql"> <!--配置事务--> <transactionManager type="JDBC"></transactionManager> <!--配置连接池--> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"></property> <property name="url" value="jdbc:mysql://localhost:3306/eesy_mybatis"></property> <property name="username" value="root"></property> <property name="password" value="root"></property> </dataSource> </environment> </environments> <!--映射配置文件的位置--> <!--注意这里用/--> <mappers> <mapper resource="com/dao/IUserDao.xml"></mapper> </mappers> </configuration>
6.编写测试类
在test中编写
通过 SqlSession 的 getMapper 方法来获取一个 Mapper 接口,就可以调用它的方法了。因为 XML 文件或者接口注解定义的 SQL 都可以通过“类的全限定名+方法名”查找,所以 MyBatis 会启用对应的 SQL 进行运行,并返回结果。
package com.test; import com.dao.IUserDao; import com.domain.User; 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 java.io.InputStream; import java.util.List; //测试mybatis的crud方法 public class MybatisTest { // 测试查询所有方法 @Test public void testfindall() throws Exception { //1读取配置文件,生成字节输入流 InputStream in= Resources.getResourceAsStream("SqlMapConfig.xml"); //2获取SqlSessionFactory SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in); //3获取SqlSession对象 SqlSession sqlSession = factory.openSession(); //4获取dao的代理对象 IUserDao userDao = sqlSession.getMapper(IUserDao.class); //5执行查询所有方法 List<User> users = userDao.findall(); for (User user : users){ System.out.println(user); } //6释放资源 sqlSession.close(); in.close(); } }
7.查询结果如下
新创建一个公众号 Rockey小何同学 想相互交流的同学可以关注一下哈! 感谢支持!