spring整合Mybatis-P23,24,25
创始人
2024-03-03 23:11:52
0

复习Mybatis(都是之前的内容,不再解释)

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

UserMapper

package com.Li.mapper;import com.Li.pojo.User;import java.util.List;public interface UserMapper {public List selectUser();
}

UserMapper.xml




User

package com.Li.pojo;import lombok.Data;@Data
public class User {private int id;private String name;private String pwd;
}

mybatis-config.xml





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 {@Testpublic 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


spring-studycom.Li1.0-SNAPSHOT4.0.0spring-10-mybatis88junitjunit4.12mysqlmysql-connector-java8.0.29org.mybatismybatis3.5.2org.springframeworkspring-webmvc5.3.23org.springframeworkspring-jdbc6.0.0org.aspectjaspectjweaver1.9.4org.mybatismybatis-spring2.0.7org.projectlomboklombok1.18.10src/main/java**/*.properties**/*.xmlfalsesrc/main/resources**/*.properties**/*.xmlfalse

测试:


整合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来执行,在原来,现在都使用SqlSessionTemplateprivate SqlSessionTemplate sqlSession;public void setSqlSession(SqlSessionTemplate sqlSession) {this.sqlSession = sqlSession;}@Overridepublic List selectUser() {UserMapper mapper = sqlSession.getMapper(UserMapper.class);return mapper.selectUser();}
}

mybatis-config.xml:(简化删减里面的内容,将里面的内容移至spring-dao.xml中)




spring-dao.xml(整合了mybatis-config.xml与spring-dao.xml,使两种xml可以互通)



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 {@Testpublic 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花了我好长时间找这个错误。。。无语

org.springframeworkspring-jdbc5.2.0.RELEASE

成功!

小结:你需要去对应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{@Overridepublic List selectUser() {SqlSession sqlSession = getSqlSession();UserMapper mapper = sqlSession.getMapper(UserMapper.class);return mapper.selectUser();}
}

applicationContext.xml:(将spring-dao.xml与mybatis-config.xml整合为一个)



修改之后测试成功!

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

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...