IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> SpringBoot+MyBatis快速搭建项目 -> 正文阅读

[Java知识库]SpringBoot+MyBatis快速搭建项目

创建SpringBoot项目

引入相关依赖

		<!-- web核心依赖 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- mybatis -->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.2.2</version>
        </dependency>
        <!-- 自动创建管理表依赖actable, 如果想手动管理可以不要这个依赖 -->
        <dependency>
            <groupId>com.gitee.sunchenbin.mybatis.actable</groupId>
            <artifactId>mybatis-enhance-actable</artifactId>
            <version>1.5.0.RELEASE</version>
        </dependency>
        
        <!-- 可以根据自己的需求配置数据库, 如果嫌麻烦直接使用H2数据库 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>2.1.212</version>
            <scope>runtime</scope>
        </dependency>

创建相应的目录结构

在这里插入图片描述

创建Entity

这里的@Table, @Id, @Column用actable或者java自己的都可以

@Data
@Builder
@Table(name = "tb_user")
public class User implements Serializable{

    /**
     * 
     */
    private static final long serialVersionUID = -8720709928795156685L;

    @Id
    private long id;
    
    @Column
    private String username;
    
    @Column
    private String password;
}

创建Mapper接口

@Mapper
public interface UserMapper {

    List<User> findAll();
    
    void save(User user);
}

Mapper文件映射

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">
 
    <!-- findAll返回的是列表,需要手动映射 -->
    <resultMap type="com.example.demo.model.User" id="userMap">
        <id column="id" property="id" jdbcType="INTEGER" />
        <result column="username" property="username" jdbcType="VARCHAR" />
        <result column="password" property="password" jdbcType="VARCHAR" />
    </resultMap>
    
    <select id="findAll" resultType="com.example.demo.model.User" resultMap="userMap">
        SELECT * FROM tb_user
    </select>
    
    <insert id="save" parameterType="com.example.demo.model.User">
        insert into tb_user values(#{id}, #{username}, #{password})
    </insert>
</mapper>

创建接口

UserService.java

public interface UserService {

    List<User> findAll();
    
    void save(User user);
}

创建实现类

UserServiceImpl.java

@Service
public class UserServiceImpl implements UserService{
    
    @Autowired
    UserMapper userMapper;

    @Override
    public List<User> findAll() {
        // 为了方便先insert一条数据
        User user = User.builder()
                .id(111)
                .username("helloworld")
                .password("still helloworld")
                .build();
        save(user);
        return userMapper.findAll();
    }

    @Override
    public void save(User user) {
        userMapper.save(user);
    }

}

创建Controller

UserController.java

@RestController
@RequestMapping("/users")
public class UserController {

    @Autowired
    private UserService userService;
    
    @GetMapping
    public List<User> findAll(){
        return userService.findAll();
    }
}

主程序入口类配置

MybatisDemoApplication.java

/*
 * com.gitee.sunchenbin.mybatis.actable.dao.* 和 
 * com.gitee.sunchenbin.mybatis.actable.manager.* 是actable的官方配置,照抄就行
 */
@SpringBootApplication
@MapperScan({ "com.gitee.sunchenbin.mybatis.actable.dao.*", "com.example.demo.mapper"})
@ComponentScan(basePackages = { "com.gitee.sunchenbin.mybatis.actable.manager.*", "com.example.demo.*"})
public class MybatisDemoApplication {

	public static void main(String[] args) {
		SpringApplication.run(MybatisDemoApplication.class, args);
	}

}

配置文件

server:
  port: 8888

spring:
  datasource:
# --- begin mysql config --- 
#    url: jdbc:mysql://localhost:3306/mybatis_demo?characterEncoding=UTF-8
#    driver-class-name: com.mysql.cj.jdbc.Driver
#    username: your_database_username
#    password: your_database_password
# --- end mysql config --- 
    url: jdbc:h2:mem:testdb;mode=MySQL
    driver-class-name: org.h2.Driver
    
mybatis: 
  mapper-locations:
  - classpath:mapper/*.xml # 自己的mapper配置目录
  # actable的官方配置,照抄就ok
  - classpath*:com/gitee/sunchenbin/mybatis/actable/mapping/*/*.xml
  table:
    # create: 会删除原有所有数据在新建; none:不作任何处理; update: 不存在新建,存在更新
    auto: update 
  model:
    pack: com.example.demo.model # entity目录
  database:
    type: mysql

启动并测试

如果之前的配置用的是H2数据库的话,直接启动后访问http://localhost:8888/users会返回如下数据,如果用的是mysql数据库的配置,请确定指定的数据库已安装并且已启动。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-d3MT9Ynb-1657447358871)(C:\Users\Lanna\AppData\Roaming\Typora\typora-user-images\image-20220710175107646.png)]

github源码

感谢阅读

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-07-17 16:07:52  更:2022-07-17 16:12:23 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 15:47:43-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码