Spring boot MyBatis数据访问实验
一. 实验目的
1.熟悉Spring Boot整合MyBatis
二. 实验内容
1、 整合MyBatis,实现登录应用:
根据实验指导,完成程序。
三. 实验过程
数据表结构图
实验项目框架图
UserController源代码
package com.example.liu.controller;
import com.example.liu.entity.User;
import com.example.liu.service.UserService;
import com.example.liu.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private UserService userService;
//查询所以,方法名需要和UserMapper.xml中的id对应
@RequestMapping("/findAll")
public List<User> findAll(){
return userService.findAll();
};
//根据姓名查询
@RequestMapping("/findByName")
public List<User>findByName(String name){
return userService.findByName(name);
};
//根据用户名模糊查询
@RequestMapping("/findByUsernameLike")
public List<User>findByUsernameLike(String username){
return userService.findByUsernameLike(username);
};
//根据id查询
@RequestMapping("/findById")
public User findById(Integer id){
return userService.findById(id);
};
//多条件动态查询
@RequestMapping("/find")
public List<User>find(User user){
return userService.find(user);
};
//分页查询
@RequestMapping("/findByPageAll")
public List<User>findByPageAll(User user){
return userService.findByPageAll(user);
};
//新增
@RequestMapping("/addSave")
public String addSave(){
User user=new User();
user.setName("lzy");
user.setUsername("lzy");
user.setPassword("lzy");
userService.addSave(user);
user.setName("qaz");
user.setUsername("qaz");
user.setPassword("qaz");
userService.addSave(user);
user.setName("qwe");
user.setUsername("qwe");
user.setPassword("qwe");
userService.addSave(user);
return "数据保存成功!";
};
//修改
@RequestMapping("/update")
public String update(){
User user=userService.findById(1);
user.setName("诸葛亮");
userService.update(user);
return "修改成功!";
};
}
MyEverpage源代码
package com.example.liu.entity;
/**
*
* 分页类
* @author Administrator
*
*/
public class MyEverpage {
private int limit;
private int offset;
public int getLimit() {
return limit;
}
public void setLimit(int limit) {
this.limit = limit;
}
public int getOffset() {
return offset;
}
public void setOffset(int offset) {
this.offset = offset;
}
}
User源代码
package com.example.liu.entity;
public class User extends MyEverpage{
private Integer id;
private String name;
private String username;
private String password;
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 String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
UserMapper源代码
package com.example.liu.mapper;
import com.example.liu.entity.User;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;
@Mapper
public interface UserMapper {
//查询所有,方法名需要和UserMapper.xml中的id对应
public List<User> findAll();
//根据姓名查询
public List<User>findByName(String name);
//根据用户名模糊查询
public List<User>findByUsernameLike(String username);
//根据id查询
public User findById(Integer id);
//多条件动态查询
public List<User>find(User user);
//分页查询
public List<User>findByPageAll(User user);
//新增
public void addSave(User user);
//修改
public void update(User user);
}
UserService源代码
package com.example.liu.service;
import com.example.liu.entity.User;
import com.example.liu.mapper.UserMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
//查询所以,方法名需要和UserMapper.xml中的id对应
public List<User> findAll(){
return userMapper.findAll();
};
//根据姓名查询
public List<User>findByName(String name){
return userMapper.findByName(name);
};
//根据用户名模糊查询
public List<User>findByUsernameLike(String username){
return userMapper.findByUsernameLike(username);
};
//根据id查询
public User findById(Integer id){
return userMapper.findById(id);
};
//多条件动态查询
public List<User>find(User user){
return userMapper.find(user);
};
//分页查询
public List<User>findByPageAll(User user){
return userMapper.findByPageAll(user);
};
//新增
public void addSave(User user){
userMapper.addSave(user);
};
//修改
public void update(User user){
userMapper.update(user);
};
}
UserMapper.xml文件源代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.liu.mapper.UserMapper">
<!--查询所有-->
<select id="findAll" resultType="User">
select * from tb_user
</select>
<!--根据姓名查询-->
<select id="findByName" parameterType="User" resultType="User">
select * from tb_user where name=#{name}
</select>
<!--根据用户名模糊查询-->
<select id="findByUsernameLike" parameterType="User" resultType="User">
select * from tb_user where username like "%"#{username}"%"
</select>
<!--根据id查询-->
<select id="findById" parameterType="User" resultType="User">
select * from tb_user where id=#{id}
</select>
<!--多条件动态查询-->
<select id="find" parameterType="User" resultType="User">
select * from tb_user where 1=1
<if test="name!='' and name!=null">
and name=#{name}
</if>
<if test="username!='' and username!=null">
and username=#{username}
</if>
</select>
<!--分页查询-->
<select id="findByPageAll" parameterType="User" resultType="User">
select * from tb_user limit #{offset},#{limit}
</select>
<!--增加-->
<insert id="addSave" parameterType="User">
insert into tb_user values(null,#{name},#{username},#{password})
</insert>
<!--修改-->
<update id="update" parameterType="User">
update tb_user set name=#{name},username=#{username},password=#{password}
where id=#{id}
</update>
</mapper>
porm.xml配置文件源代码
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.0</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>liu</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>liu</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.0.9</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.2.2</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>