源碼分析以前先搭一個mybatis的demo,這個在看源碼的時候能起到了很大的做用,由於在看源碼的時候,會恍然大悟,爲何要這麼配置,爲何要這麼寫。(老鳥能夠跳過這篇)java
pom.xmlmysql
<?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.mybatis.chenhao</groupId> <artifactId>mybatisDemo</artifactId> <version>1.0-SNAPSHOT</version> <properties> <!-- mybatis版本號 --> <mybatis.version>3.4.2</mybatis.version> </properties> <dependencies> <!--mybatis依賴 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <!-- mysql驅動包 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.44</version> </dependency> </dependencies> </project>
mybatis-config.xmlsql
<?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> <!-- 引入外部配置文件 --> <properties resource="db.properties"></properties> <environments default="default"> <environment id="default"> <transactionManager type="JDBC"></transactionManager> <dataSource type="POOLED"> <property name="driver" value="${jdbc.driver}"/> <property name="url" value="${jdbc.url}"/> <property name="username" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/> </dataSource> </environment> </environments> <mappers> <mapper class="mapper.DemoMapper"></mapper> </mappers> </configuration>
db.propertiesapache
jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/demo?useUnicode=true&characterEncoding=utf8 jdbc.username=chenhao jdbc.password=123456
Employeemybatis
package entity; /*** * *@Author ChenHao *@Description: *@Date: Created in 14:58 2019/10/26 *@Modified By: * */ public class Employee { int id; String name; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "Employee{" + "id=" + id + ", name='" + name + '\'' + '}'; } }
EmployeeMapperapp
package mapper; import entity.Employee; import java.util.List; /*** * *@Author ChenHao *@Description: *@Date: Created in 14:58 2019/10/26 *@Modified By: * */ public interface EmployeeMapper { List<Employee> getAll(); }
EmployeeMapper.xmlmaven
<?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="mapper.EmployeeMapper"> <resultMap id="baseMap" type="entity.Employee"> <result property="id" column="id" jdbcType="INTEGER"></result> <result property="name" column="name" jdbcType="VARCHAR"></result> </resultMap> <select id="getAll" resultMap="baseMap"> select * from employee </select> </mapper>
public static void main(String[] args) throws IOException { String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); SqlSession sqlSession = sqlSessionFactory.openSession(); try { EmployeeMapper employeeMapper = sqlSession.getMapper(Employee.class); List<Employee> all = employeeMapper.getAll(); for (Employee item : all) System.out.println(item); } finally { sqlSession.close(); } }
測試結果:ide
Employee{id=1, name='name1'} Employee{id=2, name='name2'} Employee{id=3, name='name3'}
好了,MyBatis HelloWorld咱們已經搭建完了,後面的源碼分析文章咱們將以這個爲基礎來分析源碼分析