IDEA2021.1Springboot入门案例

1.创建项目

在这里插入图片描述

2.快速开发springboot模块

在这里插入图片描述

3.勾选需要的依赖在这里插入图片描述

4.导入数据库

在这里插入图片描述

create table t_user
(
    user_id       varchar(100) not null
        primary key,
    user_password varchar(100) null,
    lev           tinyint      null comment '0普通用户,1表示铜牌用户,2银牌3金牌',
    points        int          null comment '随着业务逻辑变动 积分',
    user_name     varchar(100) null
);

5.mysql ->java 驼峰命名

参考mysql与java的驼峰匹配规则创建bean
示例 user_name =>userName 遇到下划线后面单词首字母大写

6.创建Bean

选择当前包
在这里插入图片描述
最后的.为类之前的为包名
在这里插入图片描述

package cn.zlf.ouuser.domain;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;


/**
 * @author Administrator
 * 下面注解意思 
 * 第一个 set get toString 方法
 * 第二个 无参构造
 * 第三个 全参构造
 * 公司中说不推荐 个人没实践过不能保证没问题,不偷懒就老老实实快捷键生成方法
 * 封装属性参考数据库注释
 */
@Data 
@NoArgsConstructor
@AllArgsConstructor
public class User {
    private String userId;
    private String userPassword;
    private Integer lev;
    private Integer points;
    private String userName;
}

当前项目结构图
在这里插入图片描述

7.添加依赖(忘记了应该一开始就添加依赖)

maven 需要自己配置和弄成国内镜像 去搜安装maven的教程和idea配置maven
忘记加依赖就和我这样注解找不到
在这里插入图片描述
添加依赖(dependencies)只能有一个出错了自己检查下maven文件一定要保证正确才行

  <dependencies>
        <!--web依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--mysql-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <!--德鲁伊阿里的数据源-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.2.6</version>
        </dependency>
        <!--springboot整合mybatis-->
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.2.0</version>
        </dependency>
        <!--骨架自带声明为springboot工程-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <!--lombok快速开发bean-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!--测试目前用不上-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

8.Controll层(控制层)

同上面创建bean的步骤 包名.类名
在这里插入图片描述

package cn.zlf.ouuser.contorller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

/**
 * @Date:2021/9/10
 * @author: ZLF
 * 注解
 * Controller 控制层的bean
 * ResponseBody 浏览器响应json串
 * Autowired 自动装配(不能理解去百度找找看原理)
 * RequestMapping 请求路径 有很多参数 value 路径值 method = RequestMethod.GET 多个参数method = {RequestMethod.GET,XXX} 
 */
@RestController
public class UserController {
    @Autowired
    private Userservice userservice;

    @RequestMapping(value = "/user/points",method = RequestMethod.GET)
    public User getUser(String userId){
        return userservice.getUser(userId);
    }
}


控制层代码
在这里插入图片描述

9.service业务层

爆红地方alt+回车创建service
在这里插入图片描述
注意是创建service接口(不过没业务可以省略,这里就不省略了以后有业务一定是按照这种模式开发)
在这里插入图片描述
回车下一步(多模块记得看看下面路径是不是自己模块的路径以防创建到别的模块中)
在这里插入图片描述
结构图
在这里插入图片描述
继续到控制层把错误解决(alt+回车快速创建方法 没有业务逻辑所以比较快)
在这里插入图片描述

10.业务层接口实现(创建实现类)

在这里插入图片描述
实现接口方法
在这里插入图片描述
在这里插入图片描述

service接口

package cn.zlf.ouuser.service;

import cn.zlf.ouuser.domain.User;

/**
 * @Date:2021/9/10
 * @author: ZLF
 */
public interface Userservice {
    User getUser(String userId);
}

serviceImpl实现类

package cn.zlf.ouuser.service.Impl;

import cn.zlf.ouuser.domain.User;
import cn.zlf.ouuser.service.Userservice;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

/**
 * @Date:2021/9/11
 * @author: ZLF
 */
@Service
public class UserServiceImpl implements Userservice {
    @Autowired
    private Usermapper usermapper;
    @Override
    public User getUser(String userId) {
        return usermapper.selectUserById(userId);
    }
}

11.持久层实现(同上alt+回车快速创建)

在这里插入图片描述
生成方法
在这里插入图片描述

可以看见业务层实现类还是有冒红的警告(是因为mapper没有注入为bean所以找不到注解加上 @Autowired(required = false 不要求编译阶段一定要找到)

在这里插入图片描述

package cn.zlf.ouuser.service.Impl;

import cn.zlf.ouuser.domain.User;
import cn.zlf.ouuser.mapper.Usermapper;
import cn.zlf.ouuser.service.Userservice;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

/**
 * @Date:2021/9/11
 * @author: ZLF
 */
@Service
public class UserServiceImpl implements Userservice {
    @Autowired(required = false)
    private Usermapper usermapper;
    @Override
    public User getUser(String userId) {
        return usermapper.selectUserById(userId);
    }
}

12.配置核心文件

a.端口号配置(选配)

# 端口号默认就是8080
server:
  port: 8080

b.mysql和druil的配置导入

mysql

spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    # 此处省略了本机如果是远程的话需要手动指定ip地址
    url: jdbc:mysql:///microtest
    username: root
    password: root
    # 德鲁伊数据源
    type: com.alibaba.druid.pool.DruidDataSource

c.mybatis

#   mybatis
mybatis:
  # 找到持久化的xml配置文件
  mapper-locations: classpath:mappers/*.xml
  #  别名包
  type-aliases-package: cn.zlf.domain
  configuration:
    #    驼峰
    map-underscore-to-camel-case: true
    #    二级缓存
    cache-enabled: false

13.持久层配置文件

创建在核心配置文件同级 resources 包名必须跟核心配置文件设置的保持一致否者找不到
在这里插入图片描述
xml文件名字可以随便取但一般要见名思意

配置mybatis 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="cn.zlf.mapper.UserMapper">
    <select id="selectUserById" parameterType="string" resultType="cn.zlf.domain.User">
        select *
        from t_user
        where user_id = #{userId};
    </select>
</mapper> 

可以看见有了个Mapper模板 直接创建就好了(模板为你设置的名字,创建另外取名见名思意)
在这里插入图片描述

在这里插入图片描述

14.启动类

在这里插入图片描述
在这里插入图片描述
启动报错看一下问题 说
在这里插入图片描述
在这里插入图片描述
很明显了xml有问题查了下是路径不正确(命名空间我没设置对要设置到你的接口mapper的路径还有类型匹配要找到对应的bean)
在这里插入图片描述
重新启动成功
在这里插入图片描述

在这里插入图片描述
根据自己的请求跟端口号匹配 后面拼接需要的参数(数据库要有数据才可以查得到之前创建数据库后可以自己添加数据进去)
在这里插入图片描述
最终结果
测试路径
GET http://localhost:8080/user/points?userId=1
在这里插入图片描述

15. 添加积分

controller层

 @RequestMapping(value = "/user/update/point")
    public Integer updatePoints(String userId, Integer money) {
        try {
            userService.updatePoints(userId, money);
            return 1;
        } catch (Exception e) {
            e.printStackTrace();
            return 0;
        }
    }

service 接口

public interface Userservice {
    User getUser(String userId);

    void updateUser(String userId, Integer point);
}

service实现类

    @Override
    public void updateUser(String userId, Integer point) {
        int points = point.intValue();
        usermapper.updateUserById(userId,points);
    }

mapper持久层接口

void updateUserById(String userId, int points);

xml配置文件更新

   update t_user
        set points =points + #{point}
        where user_id = 1;

启动类重新启动
在这里插入图片描述
更新成功
在这里插入图片描述

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐