SpringBoot整合MyBatis完整详细版,java分布式开发面试题

4、编写相关配置

在src/main/resources下找到application.properties文件,在该配置文件中配置数据源。

spring.datasource.url=jdbc:mysql://localhost:3306/mybatis?serverTimezone=GMT%2B8

spring.datasource.username=root

spring.datasource.password=root

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

#连接池的配置

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

server.port=80

#配置mapper xml文件所在的路径

mybatis.mapper-locations=classpath:mapper/*.xml

#mybatis别名包扫描,映射类所在的包名,对应实体类的包名

mybatis.type-aliases-package=com.mcy.springbootmybatis.entity

这里需要注意的是两个配置xml和实体类包路径不能出错,不然会报错。

#配置mapper xml文件所在的路径

mybatis.mapper-locations=classpath:mapper/*.xml

#mybatis别名包扫描,映射类所在的包名,对应实体类的包名

mybatis.type-aliases-package=com.mcy.springbootmybatis.entity

表结构设计


1、表结构

设计了一张tb_user用户表,表结构如下。

2、建表

执行以下脚本在数据库中创建tb_user表。

CREATE TABLE tb_user (

id int(11) NOT NULL AUTO_INCREMENT,

name varchar(255) DEFAULT NULL,

username varchar(255) DEFAULT NULL,

password varchar(255) DEFAULT NULL,

PRIMARY KEY (id)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

编写代码


在项目中新建4个包,分别为entity(放置持久化类)、controller(控制器)、mapper(定义数据访问接口的包)、service(业务逻辑处理类)。在resources目录下创建mapper文件夹。代码中有详细的注释,下面直接贴代码。

1、编写实体类

实体类User.java,其代码如下(和数据库字段需要对应,继承分页公共类MyEverpage)。

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;

}

}

分页查询参数公共类MyEverpage.java,代码如下。

/**

  • 分页类

  • @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;

}

}

2、编写xml文件,SQL查询

在resources/mapper文件夹下新建一个UserMapper.xml文件,编写查询语句,代码如下(这里的xml路径一定要和application.properties配置文件中的路径一致)。

<?xml version="1.0" encoding="UTF-8"?>

select * from tb_user

select * from tb_user where name=#{name}

select * from tb_user where username like “%”#{username}“%”

select * from tb_user where id = #{id}

select * from tb_user where 1=1

and name =#{name}

and username =#{username}

select * from tb_user limit #{offset},#{limit}

insert into tb_user values(null, #{name}, #{username}, #{password})

update tb_user set name=#{name}, username=#{username}, password=#{password}

where id=#{id}

3、编写Mapper接口

UserMapper.java接口,代码如下(需要添加@Mapper注解,方法名需要额xml中的id值对应)。

import com.mcy.springbootmybatis.entity.User;

import org.apache.ibatis.annotations.Mapper;

import java.util.List;

@Mapper

public interface UserMapper {

//查询所有,方法名需要和UserMapper.xml中的id对应

public List findAll();

//根据姓名查询

public List findByName(String name);

//根据用户名模糊查询

public List findByUsernameLike(String username);

//根据id查询

public User findById(Integer id);

//多条件动态查询

public List find(User user);

//分页查询

public List findByPageAll(User user);

//新增

public void addSave(User user);

//修改

public void update(User user);

}

3、编写业务层类

UserService.java业务层类。

import com.mcy.springbootmybatis.entity.User;

import com.mcy.springbootmybatis.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 findAll(){

return userMapper.findAll();

};

//根据姓名查询

public List findByName(String name){

return userMapper.findByName(name);

};

//根据用户名模糊查询

public List findByUsernameLike(String username){

return userMapper.findByUsernameLike(username);

};

//根据id查询

public User findById(Integer id){

return userMapper.findById(id);

};

//多条件动态查询

public List find(User user){

return userMapper.find(user);

};

//分页查询

public List findByPageAll(User user){

return userMapper.findByPageAll(user);

};

//新增

public void addSave(User user){

userMapper.addSave(user);

};

//修改

public void update(User user){

userMapper.update(user);

};

}

测试应用


1、编写测试Controller

访问控制器UserController.java类,代码如下。

import com.mcy.springbootmybatis.entity.User;

import com.mcy.springbootmybatis.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”)

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

技术学习总结

学习技术一定要制定一个明确的学习路线,这样才能高效的学习,不必要做无效功,既浪费时间又得不到什么效率,大家不妨按照我这份路线来学习。

最后面试分享

大家不妨直接在牛客和力扣上多刷题,同时,我也拿了一些面试题跟大家分享,也是从一些大佬那里获得的,大家不妨多刷刷题,为金九银十冲一波!

40126)]
[外链图片转存中…(img-tSd35zcL-1711993840127)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-COcgS3Oz-1711993840127)]

技术学习总结

学习技术一定要制定一个明确的学习路线,这样才能高效的学习,不必要做无效功,既浪费时间又得不到什么效率,大家不妨按照我这份路线来学习。

[外链图片转存中…(img-VmXBdDfJ-1711993840127)]

[外链图片转存中…(img-AGcFJVVZ-1711993840128)]

[外链图片转存中…(img-w8B1ZuEp-1711993840128)]

最后面试分享

大家不妨直接在牛客和力扣上多刷题,同时,我也拿了一些面试题跟大家分享,也是从一些大佬那里获得的,大家不妨多刷刷题,为金九银十冲一波!

[外链图片转存中…(img-9zCieBwS-1711993840128)]

[外链图片转存中…(img-mwKNtCqo-1711993840128)]

  • 15
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值