6个需要修改或创建的文件

UserMapper
- package com.Li.mapper;
-
- import com.Li.pojo.User;
-
- import java.util.List;
-
- public interface UserMapper {
- public List
selectUser(); - }
UserMapper.xml
- "1.0" encoding="UTF-8" ?>
- mapper
- PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
-
- <mapper namespace="com.Li.mapper.UserMapper">
-
-
- <select id="selectUser" resultType="user">
- select * from mybatis.user
- select>
- mapper>
User
- package com.Li.pojo;
-
- import lombok.Data;
-
- @Data
- public class User {
- private int id;
- private String name;
- private String pwd;
- }
-
mybatis-config.xml
- "1.0" encoding="UTF-8" ?>
- configuration
- PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-config.dtd">
- <configuration>
-
- <typeAliases>
- <package name="com.Li.pojo"/>
- typeAliases>
-
- <environments default="development">
- <environment id="development">
- <transactionManager type="JDBC"/>
- <dataSource type="POOLED">
- <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
- <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=false&useUnicode=true&characterEncoding=utf8"/>
- <property name="username" value="root"/>
- <property name="password" value="123456"/>
- dataSource>
- environment>
- environments>
-
- <mappers>
- <mapper resource="com/Li/mapper/UserMapper.xml"/>
- mappers>
- configuration>
MyTest
- import com.Li.mapper.UserMapper;
- import com.Li.pojo.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.IOException;
- import java.io.InputStream;
- import java.util.List;
-
- public class MyTest {
- @Test
- public void selectUser() throws IOException {
-
- String resource = "mybatis-config.xml";
- InputStream inputStream = Resources.getResourceAsStream(resource);
- SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
- SqlSession sqlSession = sqlSessionFactory.openSession();
-
- UserMapper mapper = sqlSession.getMapper(UserMapper.class);
-
- List
userList = mapper.selectUser(); - for (User user: userList){
- System.out.println(user);
- }
-
- sqlSession.close();
- }
-
- }
pom.xml
- "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">
- <parent>
- <artifactId>spring-studyartifactId>
- <groupId>com.LigroupId>
- <version>1.0-SNAPSHOTversion>
- parent>
- <modelVersion>4.0.0modelVersion>
-
- <artifactId>spring-10-mybatisartifactId>
-
- <properties>
- <maven.compiler.source>8maven.compiler.source>
- <maven.compiler.target>8maven.compiler.target>
- properties>
-
-
- <dependencies>
- <dependency>
- <groupId>junitgroupId>
- <artifactId>junitartifactId>
- <version>4.12version>
- dependency>
- <dependency>
- <groupId>mysqlgroupId>
- <artifactId>mysql-connector-javaartifactId>
- <version>8.0.29version>
- dependency>
- <dependency>
- <groupId>org.mybatisgroupId>
- <artifactId>mybatisartifactId>
- <version>3.5.2version>
- dependency>
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-webmvcartifactId>
- <version>5.3.23version>
- dependency>
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-jdbcartifactId>
- <version>6.0.0version>
- dependency>
- <dependency>
- <groupId>org.aspectjgroupId>
- <artifactId>aspectjweaverartifactId>
- <version>1.9.4version>
- dependency>
- <dependency>
- <groupId>org.mybatisgroupId>
- <artifactId>mybatis-springartifactId>
- <version>2.0.7version>
- dependency>
- <dependency>
- <groupId>org.projectlombokgroupId>
- <artifactId>lombokartifactId>
- <version>1.18.10version>
- dependency>
- dependencies>
-
- <build>
- <resources>
- <resource>
- <directory>src/main/javadirectory>
- <includes>
- <include>**/*.propertiesinclude>
- <include>**/*.xmlinclude>
- includes>
- <filtering>falsefiltering>
- resource>
- <resource>
- <directory>src/main/resourcesdirectory>
- <includes>
- <include>**/*.propertiesinclude>
- <include>**/*.xmlinclude>
- includes>
- <filtering>falsefiltering>
- resource>
- resources>
-
- build>
-
-
-
-
- project>
测试:

整合Mybatis方式一:(详解在代码中)

UserMapperImpl:(接口的实现类,用来实现 UserMapper的Mybatis)
- package com.Li.mapper;
-
- import com.Li.pojo.User;
- import org.mybatis.spring.SqlSessionTemplate;
-
- import java.util.List;
-
- public class UserMapperImpl implements UserMapper{
- //作用是简化测试类
-
- //我们的所有操作,都使用sqlSession来执行,在原来,现在都使用SqlSessionTemplate
- private SqlSessionTemplate sqlSession;
-
-
- public void setSqlSession(SqlSessionTemplate sqlSession) {
- this.sqlSession = sqlSession;
- }
-
-
-
- @Override
- public List
selectUser() { - UserMapper mapper = sqlSession.getMapper(UserMapper.class);
- return mapper.selectUser();
- }
- }
mybatis-config.xml:(简化删减里面的内容,将里面的内容移至spring-dao.xml中)
- "1.0" encoding="UTF-8" ?>
- configuration
- PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-config.dtd">
- <configuration>
-
- <typeAliases>
- <package name="com.Li.pojo"/>
- typeAliases>
-
-
- configuration>
spring-dao.xml(整合了mybatis-config.xml与spring-dao.xml,使两种xml可以互通)
- "1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- https://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/aop
- https://www.springframework.org/schema/aop/spring-aop.xsd">
-
-
-
-
- <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
- <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
- <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=false&useUnicode=true&characterEncoding=UTF-8"/>
- <property name="username" value="root"/>
- <property name="password" value="123456"/>
- bean>
-
-
-
-
- <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
- <property name="dataSource" ref="dataSource"/>
-
- <property name="configLocation" value="classpath:mybatis-config.xml"/>
-
- <property name="mapperLocations" value="classpath:com/Li/mapper/*.xml"/>
- bean>
-
-
- <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
-
- <constructor-arg index="0" ref="sqlSessionFactory"/>
- bean>
-
- <bean id="userMapper" class="com.Li.mapper.UserMapperImpl">
- <property name="sqlSession" ref="sqlSession"/>
- bean>
-
-
- beans>
Mytest:(以spring的方式来做)
- import com.Li.mapper.UserMapper;
- import com.Li.pojo.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 org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
-
- import java.io.IOException;
- import java.io.InputStream;
- import java.util.List;
-
- public class MyTest {
- @Test
- public void selectUser() throws IOException {
-
- ApplicationContext context = new ClassPathXmlApplicationContext("spring-dao.xml");
-
- UserMapper userMapper = context.getBean("userMapper", UserMapper.class);
- for (User user : userMapper.selectUser()) {
- System.out.println(user);
- }
-
- }
-
- }
测试:
Error loading class [org.springframework.jdbc.datasource.DriverManagerDataSource] for bean with name
会出现这样的红字报错。
直接改jar包的版本。。。这tm花了我好长时间找这个错误。。。无语
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-jdbcartifactId>
- <version>5.2.0.RELEASEversion>
- dependency>
成功!

小结:你需要去对应MyTest的代码,来理解你每一步操作都是在干什么。
方式二:(简化方式一)
UserMapperImpl2:(继承实现)
- package com.Li.mapper;
-
- import com.Li.pojo.User;
- import org.apache.ibatis.session.SqlSession;
- import org.mybatis.spring.support.SqlSessionDaoSupport;
-
- import java.util.List;
- //继承SqlSessionDaoSupport,不需要创建sqlSession了,可以直接用
- public class UserMapperImpl2 extends SqlSessionDaoSupport implements UserMapper{
- @Override
- public List
selectUser() { - SqlSession sqlSession = getSqlSession();
- UserMapper mapper = sqlSession.getMapper(UserMapper.class);
- return mapper.selectUser();
- }
- }
applicationContext.xml:(将spring-dao.xml与mybatis-config.xml整合为一个)
- "1.0" encoding="UTF-8"?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- https://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/aop
- https://www.springframework.org/schema/aop/spring-aop.xsd">
-
- <import resource="spring-dao.xml"/>
-
- <bean id="userMapper" class="com.Li.mapper.UserMapperImpl">
- <property name="sqlSession" ref="sqlSession"/>
- bean>
-
- <bean id="userMapper2" class="com.Li.mapper.UserMapperImpl2">
- <property name="sqlSessionFactory" ref="sqlSessionFactory"/>
- bean>
-
- beans>
修改之后测试成功!

重点在方式一的理解与掌握!