spring整合Mybatis-P23,24,25
创始人
2024-04-15 04:16:55
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整合为一个)



修改之后测试成功!

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

相关内容

热门资讯

喜闻乐见,2026年“国补”政... 12月30日,国家发展改革委、财政部印发的《关于2026年实施大规模设备更新和消费品以旧换新政策的通...
女子与表姐夫婚外情获赠三百余万... 一桩发生在海南的民间借贷纠纷,将一段持续二十余年的婚外情推到台前。相关材料显示,男子林森(化名)在婚...
诉讼纠纷频发!中央商场子公司又... 继控股子公司新亚百货面临补缴税款及滞纳金7392万元后,百货零售巨头中央商场(600280.SH)另...
从明天起,楼市迎来两大利好政策... 作者:暴哥 来源:暴财经pro 同志们,2025年要过去了! 今年,各位在股市里应该收获不少,把过去...
国台办回应台湾网红“馆长”大陆... 12月31日,国台办举行例行新闻发布会,国台办发言人张晗就近期两岸热点问题回答记者提问。 有记者提问...
中钢天源:股东中钢热能院907... 雷达财经 文|冯秀语 编|李亦辉 12月30日,中钢天源(证券代码:002057)发布公告称,其控股...
宇树科技因侵权责任纠纷案件被起... 天眼查法律诉讼信息显示,近日,杭州宇树科技股份有限公司及邵某新增1条开庭公告,原告为孙某,涉及侵权责...
今日视点:“制度创新+科技突破... 2025年,A股市场交易活跃度持续提升。截至12月30日,全年累计成交金额达417.8万亿元,同比增...
专业文章丨第二顺位抵押权人实现... 【珠海律师、珠海法律咨询、珠海律师事务所、京师律所、京师珠海律所】 (本文转载自北京市京师郑州律师事...
企业就网络谣言报案并追究法律责... 2025-12-31 09:41:29 作者:狼叫兽 声明指出,目前相关网络平台已对上述不实信息进...