导入jar包
junit
mybatis
mysql数据库
spring相关
aop织入
mybatis-spring
- "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.yuangroupId>
- <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>
- <project.build.sourceEncoding>UTF-8project.build.sourceEncoding>
- properties>
-
- <dependencies>
- <dependency>
- <groupId>junitgroupId>
- <artifactId>junitartifactId>
- <version>4.12version>
- <scope>testscope>
- dependency>
-
- <dependency>
- <groupId>mysqlgroupId>
- <artifactId>mysql-connector-javaartifactId>
- <version>5.1.47version>
- dependency>
-
- <dependency>
- <groupId>org.mybatisgroupId>
- <artifactId>mybatisartifactId>
- <version>3.5.2version>
- dependency>
-
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-webmvcartifactId>
- <version>5.2.0.RELEASEversion>
- dependency>
-
-
-
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-jdbcartifactId>
- <version>5.3.19version>
- <scope>compilescope>
- dependency>
-
-
- <dependency>
- <groupId>org.aspectjgroupId>
- <artifactId>aspectjweaverartifactId>
- <version>1.8.13version>
- dependency>
-
-
- <dependency>
- <groupId>org.aspectjgroupId>
- <artifactId>aspectjweaverartifactId>
- <version>1.8.13version>
- dependency>
-
-
-
- <dependency>
- <groupId>org.mybatisgroupId>
- <artifactId>mybatis-springartifactId>
- <version>2.0.2version>
- dependency>
-
- <dependency>
- <groupId>org.projectlombokgroupId>
- <artifactId>lombokartifactId>
- <version>1.16.10version>
- dependency>
-
- dependencies>
-
-
-
- <build>
- <resources>
- <resource>
- <directory>src/main/javadirectory>
- <includes>
- <include>**/*.xmlinclude>
- includes>
- <filtering>truefiltering>
- resource>
- resources>
- build>
-
-
- project>
- import lombok.Data;
-
- @Data
- public class User {
- private int id;
- private String name;
- private String pwd;
- }
- "1.0" encoding="UTF-8" ?>
- configuration
- PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-config.dtd">
- <configuration>
-
- <environments default="development">
- <environment id="development">
- <transactionManager type="JDBC"/>
- <dataSource type="POOLED">
- <property name="driver" 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"/>
- dataSource>
- environment>
- environments>
-
-
- <mappers>
- <mapper resource="com/yuan/mapper/UserMapper.xml"/>
- mappers>
- configuration>
- import com.yuan.pojo.User;
- import java.util.List;
-
- public interface UserMapper {
- public List
selectUser(); - }
- "1.0" encoding="UTF-8" ?>
- mapper
- PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
-
- <mapper namespace="com.yuan.mapper.UserMapper">
- <select id="selectUser" resultType="user">
- select * from mybatis.user;
- select>
-
- mapper>
- import com.yuan.mapper.UserMapper;
- import com.yuan.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 test() throws IOException {
- String resources = "mybatis-config.xml";
- InputStream in = Resources.getResourceAsStream(resources);
- SqlSessionFactory sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder().build(in);
- SqlSession sqlSession = sqlSessionFactoryBuilder.openSession(true);
- UserMapper mapper = sqlSession.getMapper(UserMapper.class);
- List
userList = mapper.selectUser(); - for (User user : userList) {
- System.out.println(user);
- }
- }
-
- }
官方文档:mybatis-spring –
1.配置数据源
2.sqlSessionFactory
配置文件spring-dao.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/yuan/mapper/*.xml"/>
- bean>
-
- <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
- <constructor-arg index="0" ref="sqlSessionFactory"/>
- bean>
-
-
-
-
- beans>
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.yuan.pojo"/>
- typeAliases>
-
-
-
- configuration>
4.实现接口
UserMapperImpl.java
- import com.yuan.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();
- }
- }
5.配置bean
这里不直接在spring-dao.xml中配置,为了保持spring-dao.xml的干净整洁,因为这个配置文件后续基本不变,新增再下面这里操作即可!
applicationContext.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.yuan.mapper.UserMapperImpl">
- <property name="sqlSession" ref="sqlSession"/>
- bean>
-
- beans>
6.测试
- import com.yuan.mapper.UserMapper;
- import com.yuan.pojo.User;
-
- import org.junit.Test;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
-
-
- public class MyTest {
-
-
- @Test
- public void test(){
- ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
- UserMapper userMapper = context.getBean("userMapper", UserMapper.class);
- for (User user : userMapper.selectUser()) {
- System.out.println(user);
- }
- }
- }
新增一个UserMapperImpl2.java
- import com.yuan.pojo.User;
- import org.apache.ibatis.session.SqlSession;
- import org.mybatis.spring.support.SqlSessionDaoSupport;
-
- import java.util.List;
-
- public class UserMapperImpl2 extends SqlSessionDaoSupport implements UserMapper{
-
-
- @Override
- public List
selectUser() { - SqlSession sqlSession = getSqlSession();
- UserMapper mapper = sqlSession.getMapper(UserMapper.class);
- return mapper.selectUser();
- }
- }
注入spring applicationContext.xml配置文件新增如下配置
- <bean id="userMapper2" class="com.yuan.mapper.UserMapperImpl2">
- <property name="sqlSessionFactory" ref="sqlSessionFactory"/>
- bean>
测试
- import com.yuan.mapper.UserMapper;
- import com.yuan.pojo.User;
-
- import org.junit.Test;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
-
-
- public class MyTest {
-
-
- @Test
- public void test(){
- ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
- UserMapper userMapper = context.getBean("userMapper2", UserMapper.class);
- for (User user : userMapper.selectUser()) {
- System.out.println(user);
- }
- }
- }