MyBatis快速上手
利用mybatis实现一个学生管理的增删改查
首先是配置文件

数据库连接配置文件
高版本大于5的数据库 连接时 需要加入时区
driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/db3?useUnicode=true&characterEncoding=gbk&useSSL=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=Hongkong
username=root
password=123456
日志文件配置
log4j.rootLogger=DEBUG, Console
#Console
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=5p [%t] - %m%n
mybatis配置映射文件
常规操作建立 对应的User封装类
MybatisConfig,xml
<!--DTD约束-->
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<!--核心跟标签-->
<configuration>
<!-- 引入数据库连接的配置文件-->
<properties resource="jdbc.properties"/>
<!-- 配置LOG4J-->
<settings>
<setting name="logImpl" value="log4j"/>
</settings>
<!-- 起别名 -->
<typeAliases>
<typeAlias type="bean.Student" alias="student"/>
<!-- 给这包下所有的类 起别名 别名就是这个类名 <package name="bean"/>-->
</typeAliases>
<!--集成分页助手插件-->
<plugins>
<plugin interceptor="com.github.pagehelper.PageHelper">
<!-- <property name="dialect" value="mysql"/>-->
<!-- <property name="reasonable" value="true" />-->
</plugin>
</plugins>
<!-- 和id保持对应 表示采用那个配置 配置数据库环境配置的 default 指定具体那个环境 id 唯一的标识-->
<environments default="mysql">
<environment id="mysql">
<!--采用JDBC的事务-->
<transactionManager type="JDBC"></transactionManager>
<!-- 数据源信息 代表数据库连接池-->
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
<!-- 引入映射配置文件-->
<mappers>
<!-- resource 属性指定映射配置文件的名称-->
<mapper resource="StudentMapper.xml"/>
</mappers>
</configuration>
在这里插入代码片
paging 一个分页的插件 用的是Pagehelper
package paging;
import bean.Student;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import mapper.StudentMapper;
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.InputStream;
import java.util.List;
// 通过mybatis 实现了 分页进行查询
// 分页的功能
// 对应的 分页sql语句 第一页 显示三条数据 当前页(当前页-1 * 每页显示条数) 每页显示条数
// SELECT * FROM student LIMIT 0,3
public class Test01 {
@Test
public void selectPaging() throws Exception{
InputStream is = Resources.getResourceAsStream("MybatisConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
// 相当于 一个 表单的提交
SqlSession sqlSession = sqlSessionFactory.openSession(true);
// 获取接口类 实现对象
StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);
// 分页助手显示分页
// 分页可以将很多条结果 进行分页显示
// 第一页 显示三条数据
PageHelper.startPage(1,100); // 设置分页参数
List<Student> list = mapper.selectAll();
for (Student student : list) {
System.out.println(student);
}
// 获取分页参数 分页相关参数功能类
PageInfo info = new PageInfo<>(list);
System.out.println("总条数:"+info.getTotal());
System.out.println("总页数:"+info.getPages());
System.out.println("当前页:"+info.getPageNum());
System.out.println("每页显示条数:"+info.getPageSize());
sqlSession.close();
is.close(

本文介绍了如何使用MyBatis实现学生管理系统的增删改查功能,并结合PageHelper插件实现分页查询。配置了数据库连接、日志和MyBatis核心配置,包括数据源、事务管理、别名设置和分页插件。在Mapper接口和XML映射文件中定义了SQL操作,最后展示了Service和Controller层的实现,以及分页查询的测试用例。
最低0.47元/天 解锁文章
3050

被折叠的 条评论
为什么被折叠?



