SpringBoot整合MyBatis的代码详解

2023-01-21 0 3,801

目录

SpringBoot整合MyBatis

SpringBoot整合MyBatis的代码详解

依赖的导入

整合mybatis之前我们需要相对应的导入相关依赖。

<dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.3.2</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.12</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.2.1</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.6</version>
        </dependency>

大致目录

SpringBoot整合MyBatis的代码详解

我们首先需要在java的目录和resources下创建mapper文件夹。前者是方法的接口,后者则是xml文件的编写。

例如:

@Mapper
@Repository
public interface UserLoginMapper {
    //查询
    public List<User> queryAll();
    //添加数据
    public int add(User user);
    //根据用户名查询数据
    public User queryByName(String name);

}

xml实现

<mapper namespace=\"com.example.springbootdemo03.mapper.UserLoginMapper\">
    <select id=\"queryAll\" resultType=\"com.example.springbootdemo03.bean.User\">
        select * from student
    </select>
    <insert id=\"add\" parameterType=\"com.example.springbootdemo03.bean.User\">
        insert into student values (#{name},#{password})
    </insert>
    <select id=\"queryByName\" resultType=\"com.example.springbootdemo03.bean.User\">
        select * from student where name = #{name}
    </select>
</mapper>

相关文件配置

我们可以使用yml文件也可以使用properties两种文件选择一个(当然也都可以都用)。

配置:

#配置mapper
mybatis.mapper-locations=classpath:mapper/*.xml 
mybatis.type-aliases-package=com.example.springbootdemo03.mapper
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/mysql1?serverTimezone=GMT%2B8&useSSL=true
    username: root
    password: 密码
  jdbc:
    template:
      query-timeout: 3

创建数据库和相对应的Pojo类

数据库格式:

SpringBoot整合MyBatis的代码详解

POJO类:

@AllArgsConstructor
@NoArgsConstructor
@Data
public class User {
    private Integer id;
    private String name;
    private  String password;
    private String sex;
    private String fullName;
    private String email;
}

Service层的编写

UserLogin接口的编写:

public interface UserLogin {
    /**
     *查询用户名是否存在
     */
    public Boolean IsExit(String name);
    /**
     * 判断账号密码是否存在
     * @param name
     * @return
     */
    public User Login(String name);
}

UserLoginImpl接口实现类的编写:

@Service
public class UserLoginImpl implements UserLogin {
    //自动注入UserLoginMapper
    @Autowired
    UserLoginMapper userLoginMapper;

    @Override
    public Boolean IsExit(String name){
        if(userLoginMapper.queryByName(name) == null){
            return false;
        }else return true;
    }
    @Override
    public User Login(String name) {
        User user = userLoginMapper.queryByName(name);
        return user;
    }
}

Controller层的编写

我们可以通过Controller层编写来测试登录注册。

@Autowired
    UserLogin userLogin;
    @GetMapping(value = {\"/\",\"/login\"})
    public String Index(){
        return \"login\";
    }
    @GetMapping(\"main.html\")
    public String Main(){
        return \"index\";
    }
    @PostMapping(\"/login\")
    public String Login(User user, HttpSession session, Model model){
        if(!userLogin.IsExit(user.getName())){
            session.setAttribute(\"msg\", \"登录失败\");
            return \"redirect:/login\";
        }
        User login = userLogin.Login(user.getName());
        if(user.getName().equals(login.getName()) && user.getPassword().equals(login.getPassword())){
            session.setAttribute(\"loginUser\",user);
            return \"redirect:/main.html\";
        }
        else {
            session.setAttribute(\"msg\", \"登录失败\");
            return \"redirect:/login\";
        }
    }

登录测试

登录成功时:

SpringBoot整合MyBatis的代码详解

会跳转到主页面

SpringBoot整合MyBatis的代码详解

登录失败时:

SpringBoot整合MyBatis的代码详解

会重定向到这个页面

SpringBoot整合MyBatis的代码详解

:本文采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可, 转载请附上原文出处链接。
1、本站提供的源码不保证资源的完整性以及安全性,不附带任何技术服务!
2、本站提供的模板、软件工具等其他资源,均不包含技术服务,请大家谅解!
3、本站提供的资源仅供下载者参考学习,请勿用于任何商业用途,请24小时内删除!
4、如需商用,请购买正版,由于未及时购买正版发生的侵权行为,与本站无关。
5、本站部分资源存放于百度网盘或其他网盘中,请提前注册好百度网盘账号,下载安装百度网盘客户端或其他网盘客户端进行下载;
6、本站部分资源文件是经压缩后的,请下载后安装解压软件,推荐使用WinRAR和7-Zip解压软件。
7、如果本站提供的资源侵犯到了您的权益,请邮件联系: 442469558@qq.com 进行处理!

猪小侠源码-最新源码下载平台 Java教程 SpringBoot整合MyBatis的代码详解 http://www.20zxx.cn/463455/xuexijiaocheng/javajc.html

猪小侠源码,优质资源分享网

常见问题
  • 本站所有资源版权均属于原作者所有,均只能用于参考学习,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,建议提前注册好百度网盘账号,使用百度网盘客户端下载
查看详情

相关文章

官方客服团队

为您解决烦忧 - 24小时在线 专业服务