案例:基于MyBatis注解的学生管理程序

这篇具有很好参考价值的文章主要介绍了案例:基于MyBatis注解的学生管理程序。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、任务目标

现有一个学生表s_student和一个班级表c_class,其中,班级表c_class和学生表s_student是一对多的关系。学生表s_student和班级表c_class如表1和表2所示。
案例:基于MyBatis注解的学生管理程序
请使用MyBatis注解完成以下几个要求:

(1)MyBatis注解实现查询操作

根据表1和表2在数据库分别创建一个学生表s_student和一个班级表c_class, 并查询id为2的学生的信息。

(2)MyBatis注解实现修改操作

修改id为4的学生的姓名修改为李雷,年龄修改为21。
MyBatis注解实现修改操作

(3)MyBatis注解实现一对多查询

查询出二班所有学生的信息。

二、【实现步骤】:MyBatis注解实现查询操作

1.项目搭建

创建一个名称为mybatis-4的项目,项目的具体搭建过程请参考入门笔记
案例:基于MyBatis注解的学生管理程序

2.数据库准备

在名为mybatis的数据库中,创建两个数据表,分别为学生表s_student和班级表c_class,同时在表中预先插入几条测试数据。执行的SQL语句如下所示。

USE mybatis;
# 创建一个名称为c_class的表
CREATE TABLE c_class (
  id int(32) PRIMARY KEY AUTO_INCREMENT,
  classname varchar(40)
 );
# 插入2条数据
INSERT INTO c_class VALUES (1, '一班');
INSERT INTO c_class VALUES (2, '二班');
# 创建一个名称为s_student的表
CREATE TABLE s_student (
  id int(32) PRIMARY KEY AUTO_INCREMENT,
  name varchar(40),
  age int,
  cid int(32) NOT NULL,
  FOREIGN KEY(cid) REFERENCES c_class(id)
 );
# 插入4条数据
INSERT INTO s_student VALUES (1, '张三', 18,1);
INSERT INTO s_student VALUES (2, '李四', 18,2);
INSERT INTO s_student VALUES (3, '王五', 19,2);
INSERT INTO s_student VALUES (4, '赵六', 20,1);

案例:基于MyBatis注解的学生管理程序

3.POJO类准备

在项目的src/main/java目录下创建com.lyrpx.pojo包,在com.lyrpx.pojo包中创建持久化类IClass,并在类中定义相关属性和方法,该类用于封装IClass对象的id、班级名称以及关联的学生集合等属性。具体代码如下所示。

IClass.java

package com.lyrpx.pojo;

import java.util.List;

/**
 * 班级持久化类
 */
public class IClass {
    private Integer id;                       // 主键id
    private String classname;                // 班级名称
    private List<IStudent> studentList;    // 学生集合

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getClassname() {
        return classname;
    }

    public void setClassname(String classname) {
        this.classname = classname;
    }

    public List<IStudent> getStudentList() {
        return studentList;
    }

    public void setStudentList(List<IStudent> studentList) {
        this.studentList = studentList;
    }

    @Override
    public String toString() {
        return "IClass{" +
                "id=" + id +
                ", classname='" + classname +
                ", studentList=" + studentList + '}';
    }
}


在com.lyrpx.pojo包中,创建持久化类IStudent,并在类中定义相关属性和方法,该类用户封装IStudent对象的id、姓名和年龄等属性。具体代码如下所示。

IStudent.java

package com.lyrpx.pojo;

/**
 * 学生持久化类
 */
public class IStudent {
    private Integer id;       // 主键id
    private String name;      // 姓名
    private int age;           // 年龄

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Student{" + "id=" + id +
                ", name='" + name + ", age=" + age + '}';
    }
}


上述代码中,分别定义了各自的属性以及对应的getter/setter方法,同时为了方便查看输出结果,重写了toString()方法。

4.创建Mapper接口

在项目的src/main/java目录下创建com.lyrpx.dao包,并在com.lyrpx.dao包下创建IStudentMapper接口,用于编写@Select注解映射的select查询语句。IStudentMapper接口具体代码如下所示。

IStudentMapper.java

package com.lyrpx.mapper;


import com.lyrpx.pojo.IStudent;
import org.apache.ibatis.annotations.Select;

public interface IStudentMapper {
    @Select("select * from s_student where id = #{id}")
    IStudent selectStudent(int id);
}

上述代码中,@Select注解的参数是一个查询语句,当程序调用@Select注解标注的selectStudent ()方法时,@Select注解中映射的查询语句将被执行。

5. 修改mybatis-config.xml核心配置文件

在核心配置文件mybatis-config.xml中的元素下引入IStudentMapper接口,将IStudentMapper接口加载到核心配置文件中,具体代码如下所示。

   <mappers>
<mapper class="com.lyrpx.mapper.IStudentMapper"/>
    </mappers>

6.编写MyBatisUtils工具类

在项目src/main/java目录下创建com.lyrpx.utils包,在com.lyrpx.utils包下创建MyTool 工具类,该类用于封装读取配置文件信息的代码。具体代码如下所示。

MyTool .java

package com.lyrpx.utils;
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 java.io.InputStream;

public class MyTool {
    private static SqlSessionFactory factory;//静态工厂
    static {//创建静态工厂对象
        try {
            InputStream in = Resources.getResourceAsStream("mybatis-config.xml");
             factory=new SqlSessionFactoryBuilder().build(in);
        }catch (Exception e){
            e.printStackTrace();
        }
    }
    //获取回话对象
    public static SqlSession getSqlSession() {
        return factory.openSession(true);
    }
}

7 编写测试方法

为了验证上述配置,在项目的src/test/java目录下创建Test文件夹,在Test文件夹创建测试类MyTest,在测试类MyTest中编写测试方法findIStudentByIdTest (),具体代码如下所示。

 1@Test
 2public void findIStudentByIdTest() {
 3    // 1.通过工具类获取SqlSession对象
 4    SqlSession session = MyBatisUtils.getSession();
 5    IStudentMapper mapper = session.getMapper(IStudentMapper.class);
 6    // 2.使用IStudentMapper对象查询id为1的学生的信息
 7    IStudent student = mapper.selectStudent(2);
 8    System.out.println(student.toString());
 9    // 3.关闭SqlSession
 10    session.close();
 11}

findIStudentByIdTest()方法的运行结果
案例:基于MyBatis注解的学生管理程序

三、【实现步骤】:MyBatis注解实现一对多查询

1. 修改Mapper接口

(1)在IStudentMapper接口中编写selectStudentByCid()方法,通过cid查询对应班级中的学生信息。

selectStudentByCid()方法具体代码如下所示。

 @Select("select * from s_student where cid=#{id} ")
 @Results({@Result(id = true,column = "id",property = "id"),
         @Result(column = "classname",property = "classname")
 })
 List<IStudent> selectStudentByCid(int cid);

上述代码中,第1行代码使用@Select注解映射根据c_id查询IStudent对象的SQL语句,当程序调用@Select注解标注的selectStudentByCid
()方法时,@Select注解中映射的查询语句将被执行;第2~4行代码使用@Results注解映射查询结果,在@Results注解中,使用@Result注解完成IStudent实体类中属性和数据表中字段的映射。

(2)在项目的com.lyrpx.mapper包下创建IClassMapper接口,在该接口中编写selectClassById ()方法,通过id查询班级信息。
IClassMapper接口具体代码如下所示。

package com.lyrpx.mapper;

import com.lyrpx.pojo.IClass;
import org.apache.ibatis.annotations.Many;
import org.apache.ibatis.annotations.Result;
import org.apache.ibatis.annotations.Results;
import org.apache.ibatis.annotations.Select;
public interface IClassMapper {
    @Select("select * from c_class where id=#{id} ")
    @Results({@Result(id = true, column = "id", property = "id"),
            @Result(column = "classname", property = "classname"),
            @Result(column = "id", property = "studentList",
                    many = @Many(select =
                            "com.lyrpx.mapper.IStudentMapper.selectStudentByCid"))})
    IClass selectClassById(int id);
}

上述代码中,第8行代码使用@Select注解映射根据id查询IClass对象的SQL语句,当程序调用@Select注解标注的selectClassById
()方法时,@Select注解中映射的查询语句将被执行; 第9 ~
13行代码使用@Results注解映射查询结果,在@Results注解中,使用3个@Result注解完成IClass实体类中属性和数据表中字段的映射。其中,第12~13行代码通过@Many注解表明数据表c_class和s_student之间是一对多关联关系。在@Many注解中,select属性用于指定关联属性studentList的值是通过执行com.lyrpx.dao包中IStudentMapper接口定义的selectStudentByCid
()方法获得的。

2. 修改mybatis-config.xml核心配置文件

在核心配置文件mybatis-config.xml中的元素下引入IClassMapper接口,将IClassMapper接口加载到核心配置文件中,具体代码如下所示。

 <mapper class="com.lyrpx.mapper.IClassMapper"/>

3. 编写测试方法

为了验证上述配置,可以在测试类MyTest中,编写测试方法selectClassByIdTest (),具体代码如下所示。

 @Test
 public void selectClassByIdTest() {
    // 1.通过工具类生成SqlSession对象
    SqlSession session = MyTool.getSession();
    IClassMapper mapper = session.getMapper(IClassMapper.class);
     // 2.查询id为2的班级中学生的信息
     IClass icalss = mapper.selectClassById(2);
 System.out.println(icalss.toString());
     session.close();
}

效果图
案例:基于MyBatis注解的学生管理程序文章来源地址https://www.toymoban.com/news/detail-411056.html

到了这里,关于案例:基于MyBatis注解的学生管理程序的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 基于Python 课程设计-学生管理系统(附源码+可执行程序)

    基于Python 课程设计-学生管理系统(附源码+可执行程序) 非常完整的一个项目,可以作为课程设计去学习。 本系统的完整源码在文章结尾处,大家自行获取即可。 本系统的软件开发及运行环境具体如下。 操作系统:Windows 7、Windows 10。 Python版本:Python 3.7.0。 开发工具

    2024年02月06日
    浏览(42)
  • java毕业设计——基于JSP+sqlserver的学生信息管理系统设计与实现(毕业论文+程序源码)——学生信息管理系统

    大家好,今天给大家介绍基于JSP+sqlserver的学生信息管理系统设计与实现,文章末尾附有本毕业设计的论文和源码下载地址哦。需要下载开题报告PPT模板及论文答辩PPT模板等的小伙伴,可以进入我的博客主页查看左侧最下面栏目中的自助下载方法哦 文章目录: 随着学校规模的

    2024年02月04日
    浏览(42)
  • 基于微信小程序的班级学生作业管理系统设计与实现

    💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/华为云/阿里云等平台优质作者。 👇🏻 精彩专栏 推荐订阅👇🏻 计算机毕业设计精品项目案例-200套 🌟 文末获取源码+数据库+文档 🌟 感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编

    2024年01月21日
    浏览(37)
  • asp毕业设计——基于asp+access的学生排课管理系统设计与实现(毕业论文+程序源码)——学生排课管理系统

    大家好,今天给大家介绍基于asp+access的学生排课管理系统设计与实现,文章末尾附有本毕业设计的论文和源码下载地址哦。需要下载开题报告PPT模板及论文答辩PPT模板等的小伙伴,可以进入我的博客主页查看左侧最下面栏目中的自助下载方法哦 文章目录: 选排课系统功能的

    2024年02月04日
    浏览(30)
  • 基于微信小程序学生信息管理系统 可做毕业设计参考

    学生信息管理系统是一个教育单位不可缺少的部分。一个功能齐全、简单易用的信息管理系统不但能有效地减轻学校相关工作人员的工作负担,它的内容对于学校的决策者和管理者来说都至关重要,所以学生信息管理系统应该能够为用户提供充足的信息和快捷的查询手段。但

    2024年02月03日
    浏览(32)
  • 基于微信小程序的高校大学生社团管理系统设计与实现

    💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/知乎/华为云/阿里云等平台优质作者。 👇🏻 精彩专栏 推荐订阅👇🏻 计算机毕业设计精品项目案例(持续更新) 🌟 文末获取源码+数据库+文档 🌟 感兴趣的可以先收藏起来,还有大家在毕设选题,项

    2024年01月25日
    浏览(63)
  • 学生信息管理案例

    今天给大家带来如何使用js来实现学生信息管理的事件案例 首先是简单的HTML部分,就是一个简单的表格设置,至于autocomplete是什么意思,在这里解释一下,这个如果AutoComplete控件就是指用户在文本框输入前几个字母或是汉字的时候,该控件就能从存放数据的文本或是数据库里

    2024年02月13日
    浏览(15)
  • 基于Springboot 中小学生收费管理系统小程序-计算机毕设 附源码 59660

    摘要 1 绪论 1.1 开发背景与意义 1.2开发现状 1.3springboot框架介绍 1.4小程序框架以及目录结构介绍 2 Springboot中小学生收费管理系统小程序系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 操作可行性分析 2.2 系统流程分析 2.2.1  数据增加流程 2.2.2 数据修改

    2024年02月19日
    浏览(29)
  • 基于微信小程序+VUE+Springboot+Mysql的中小学生作业管理系统

    ✌全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅 文末获取项目下载方式 🍅 一、项目背景介绍: 近年来,随着信息技术的发展和普及,中小学生作业

    2024年02月11日
    浏览(40)
  • 第八节 学生管理系统 (阶段案例)

    管理系统,主要任务就是使用计算机对学生的各种信息进行日常管理,如: 添加 删除 修改 查询 退出系统 程序设计思路 打印 “学生管理系统” 的功能菜单,提示用户选择功能序号; print_menu() 打印函数 1.3.1 输出提示界面 程序的功能界面提示信息的作用就是,让用户根据提示

    2024年02月16日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包