一、项目要求

现有一个学生表s_student和一个班级表c_class,其中,班级表c_class和学生表s_student是一对多的关系。学生表s_student和班级表c_class如表1和表2所示。

表1  学生表(s_student)

学生id id 学生姓名 name 学生年龄 age 所属班级 cid 1 张三 18 1 2 李四 18 2 3 王五 19 2 4 赵六 20 1

表2  班级表(c_class)

班级id id 班级名称 classname             1              一班             2              二班

请使用MyBatis注解完成以下几个要求:

     1.MyBatis注解实现查询操作

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

     2.MyBatis注解实现修改操作

      修改id为4的学生的姓名修改为李雷,年龄修改为21。

      3.MyBatis注解实现一对多查询

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

二、代码实现

1、项目结构图

2、项目搭建

创建一个名称为mybatis-demo03的Maven项目

3、数据库准备

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

USE mydb;

# 创建一个名称为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);

4、POJO类准备

创建学生持久化类

package com.itheima.pojo;

/**

* 创建学生持久化类

*/

public class IStudent {

private Integer id;//主键id

private String name;//姓名

private int age;//年龄

public int getCid() {

return cid;

}

public void setCid(int cid) {

this.cid = cid;

}

private int cid;

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 "IStudent{" +

"id=" + id +

", name='" + name + '\'' +

", age=" + age +

'}';

}

}

创建班级持久化类 

package com.itheima.pojo;

import java.util.List;

/**

* 班级持久化类

*/

public class Iclass {

private Integer id;

private String classname;

private ListstudentList;

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 getStudentList() {

return studentList;

}

public void setStudentList(List studentList) {

this.studentList = studentList;

}

@Override

public String toString() {

return "Iclass{" +

"id=" + id +

", classname='" + classname + '\'' +

", studentList=" + studentList +

'}';

}

}

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

5、创建Mapper接口

(1)在项目的src/main/java目录下创建com.itheima.dao包,并在com.itheima.dao包下创建IStudentMapper接口,具体要点:1、编写@Select注解映射的select查询语句,2、添加更新s_student表中数据的方法,并在方法上添加@Update注解,3、编写selectStudentByCid()方法,通过cid查询对应班级中的学生信息

IStudentMapper接口具体代码如下所示。

package com.itheima.dao;

import com.itheima.pojo.IStudent;

import org.apache.ibatis.annotations.Result;

import org.apache.ibatis.annotations.Results;

import org.apache.ibatis.annotations.Select;

import org.apache.ibatis.annotations.Update;

import java.util.List;

public interface IStudentMapper {

@Select("select id, name, age, cid as cid from s_student where id = #{id}")

IStudent selectStudent(int id);

@Update("update s_student set name = #{name}, age = #{age} where id = #{id}")

int updateStudent(IStudent student);

@Select("select *from s_student where cid=#{id}")

@Results({@Result(id = true,column = "id",property = "id"),

@Result(column = "classname",property = "classname")}

)

List selectStudentByCid( int cid);

}

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

package com.itheima.dao;

import com.itheima.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注解映射根据id查询IClass对象的SQL语句,当程序调用@Select注解标注的selectClassById ()方法时,@Select注解中映射的查询语句将被执行

// @Results注解映射查询结果,在@Results注解中,使用3个@Result注解完成IClass实体类中属性和数据表中字段的映射

// @Many注解表明数据表c_class和s_student之间是一对多关联关系。

// 在@Many注解中,select属性用于指定关联属性studentList的值是通过执行com.itheima.dao包中IStudentMapper接口定义的selectStudentByCid ()方法获得的

@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.itheima.dao.IStudentMapper.selectStudentByCid"))})

Iclass selectClassById(int id);

}

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

PUBLIC "-//mybatis.org//DTD Config 3.0//EN"

"http://mybatis.org/dtd/mybatis-3-config.dtd">

 db.properties

mysql.driver=com.mysql.cj.jdbc.Driver

mysql.username=root

mysql.password=root

mysql.url=jdbc:mysql://localhost:3306/mydb?serverTimezone=UTC&characterEncoding=utf8

7、编写MyBatisUtils工具类

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

package com.itheima.utils;

import java.io.Reader;

import org.apache.ibatis.io.Resources;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import org.apache.ibatis.session.SqlSessionFactoryBuilder;

/**

* 工具类

*/

public class MyBatisUtils {

private static SqlSessionFactory sqlSessionFactory = null;

// 初始化SqlSessionFactory对象

static {

try {

// 使用MyBatis提供的Resources类加载MyBatis的配置文件

Reader reader = Resources.getResourceAsReader("mybatis-config.xml");

// 构建SqlSessionFactory工厂

sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);

} catch (Exception e) {

e.printStackTrace();

}

}

// 获取SqlSession对象的静态方法

public static SqlSession getSession() {

return sqlSessionFactory.openSession();

}

}

//创建MyBatisUtils工具类,该类用于封装读取配置文件信息的代码。

8、编写测试类 

package com.itheima.dao;

import com.itheima.pojo.IStudent;

import com.itheima.pojo.Iclass;

import com.itheima.utils.MyBatisUtils;

import org.apache.ibatis.session.SqlSession;

import org.junit.Test;

public class IStudentMapperTest {

//查询id为2的学生的信息

@Test

public void findIStudentByIdTest() {

// 1.通过工具类获取SqlSession对象

SqlSession session = MyBatisUtils.getSession();

IStudentMapper mapper = session.getMapper(IStudentMapper.class);

// 2.使用IStudentMapper对象查询id为1的学生的信息

IStudent student = mapper.selectStudent(2);

System.out.println(student.toString());

// 3.关闭SqlSession

session.close();

}

//修改id为4的学生的姓名修改为李雷,年龄修改为21。

@Test

public void updateIStudentTest() {

// 1.通过工具类生成SqlSession对象

SqlSession session = MyBatisUtils.getSession();

IStudent student = new IStudent();

student.setId(4);

student.setName("李雷");

student.setAge(21);

IStudentMapper mapper = session.getMapper(IStudentMapper.class);

// 2.更新学生信息(利用判断语句检查更新操作)

int result = mapper.updateStudent(student);

if (result > 0) {

System.out.println("成功更新" + result + "条数据");

} else {

System.out.println("更新数据失败");

}

System.out.println(student.toString());

session.commit(); // 进行增删改操作时注意释放SqlSession再关闭

// 3.关闭SqlSession

session.close();

}

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

@Test

public void selectClassByIdTest() {

// 1.通过工具类生成SqlSession对象

SqlSession session = MyBatisUtils.getSession();

IClassMapper mapper = session.getMapper(IClassMapper.class);

// 2.查询id为2的班级中学生的信息

Iclass icalss = mapper.selectClassById(2);

System.out.println(icalss.toString());

session.close();

}

}

9、代码测试结果

 三、总结

本项目旨在利用注解式开发简化对MyBatis框架的使用,结果显而易见是成功的,项目整体分层很清晰,利用dao层实现创建Mapper接口(对于dao层作用见后总结)

1.MyBatis的常用注解及其作用。

@Select:用于映射查询语句,其作用等同于xml配置文件中的