MyBatis视图与Spring Boot集成案例

发布时间:2024-10-14 15:53:01 作者:小樊
来源:亿速云 阅读:78

MyBatis视图与Spring Boot集成案例

一、项目准备

  1. 创建Spring Boot项目,可以使用Spring Initializr(https://start.spring.io/)快速生成。
  2. 添加MyBatis和MyBatis-Spring-Boot-Starter依赖到项目中。

二、配置MyBatis

  1. application.propertiesapplication.yml中配置MyBatis的相关属性,如数据源、映射文件位置等。

示例:

# application.properties
mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.type-aliases-package=com.example.demo.entity
  1. 创建实体类(Entity)和映射文件(Mapper XML)。

示例实体类:

package com.example.demo.entity;

public class User {
    private Long id;
    private String name;
    private Integer age;
    // 省略getter和setter方法
}

示例映射文件:

<?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.demo.mapper.UserMapper">
    <resultMap id="UserResultMap" type="com.example.demo.entity.User">
        <id property="id" column="id"/>
        <result property="name" column="name"/>
        <result property="age" column="age"/>
    </resultMap>
    <select id="selectUserById" resultMap="UserResultMap">
        SELECT * FROM user WHERE id = #{id}
    </select>
</mapper>

三、配置视图

  1. application.propertiesapplication.yml中配置视图的相关属性,如视图名称、模板引擎等。

示例:

# application.properties
spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.suffix=.html
  1. 创建视图文件(View),例如user.html

示例视图文件:

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <title>User Details</title>
</head>
<body>
    <h1>User Details</h1>
    <p th:text="${user.name}"></p>
    <p th:text="${user.age}"></p>
</body>
</html>

四、集成MyBatis视图与Spring Boot

  1. 创建Mapper接口和对应的实现类。

示例Mapper接口:

package com.example.demo.mapper;

import com.example.demo.entity.User;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;

@Mapper
public interface UserMapper {
    List<User> selectAll();
}

示例Mapper实现类(使用注解方式):

package com.example.demo.mapper;

import com.example.demo.entity.User;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;

@Mapper
public interface UserMapper {
    @Select("SELECT * FROM user")
    List<User> selectAll();
}

或者使用XML方式:

示例映射文件(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.demo.mapper.UserMapper">
    <resultMap id="UserResultMap" type="com.example.demo.entity.User">
        <id property="id" column="id"/>
        <result property="name" column="name"/>
        <result property="age" column="age"/>
    </resultMap>
    <select id="selectAll" resultMap="UserResultMap">
        SELECT * FROM user
    </select>
</mapper>

示例Mapper接口:

package com.example.demo.mapper;

import com.example.demo.entity.User;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;

@Mapper
public interface UserMapper {
    List<User> selectAll();
}
  1. 在Controller中调用Mapper接口并返回视图名称。

示例Controller:

package com.example.demo.controller;

import com.example.demo.entity.User;
import com.example.demo.mapper.UserMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;

import java.util.List;

@Controller
public class UserController {
    @Autowired
    private UserMapper userMapper;

    @GetMapping("/users")
    public String listUsers(Model model) {
        List<User> users = userMapper.selectAll();
        model.addAttribute("users", users);
        return "user";
    }
}

五、运行项目

启动Spring Boot项目,访问http://localhost:8080/users,即可看到MyBatis视图与Spring Boot集成的效果。

推荐阅读:
  1. Spring Boot 如何实现与MyBatis搭配使用
  2. MyBatis与Spring Boot集成优势

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mybatis

上一篇:MyBatis视图与数据备份恢复

下一篇:MyBatis视图与安全性设计

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》