Springboot案例_小橘啊的博客-程序员秘密_springboot案例

技术标签: spring boot  java  mysql  

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;

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

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_43955659/article/details/120228944

智能推荐

javascript--第11章--DOM扩展_watin_csdn的博客-程序员秘密

原文链接:https://www.cnblogs.com/xiaoxiaoyihan/p/5692133.htmlDOM1级主要定义了文档的底层结构,并提供了基本的查询操作的API,总体而言这些API已经比较完善,我们可以通过这些API完成大部分的DOM操作。然而,为了扩展DOM API的功能,同时进一步提高DOM操作的效率,DOM扩展也不断被提出和采纳。对DOM的扩展主要有两部分:Selecto...

VScode 常用快捷键_vscode删除一行代码快捷键_yu_Phoebe的博客-程序员秘密

1、!+Tab 建 自动生成html模板2、注释:a)单行注释:【ctrl+k,ctrl+c】或【ctrl+/】b)取消单行注释:【ctrl+k,ctrl+u】(按下ctrl不放,再按k或u)c)多行注释:【ctrl+shift+A】或 /**3、复制当前行:shift+alt+up/down4、删除当前行:shift+ctrl+k5、控制台终端显示与隐藏:crtl+~6、代码格式化:shift+alt+f7、新建一个窗口:shift+ctrl+n8、行增加缩进:ct

HTTP Status 404 - No result defined for action_xblueskyleng的博客-程序员秘密

No result defined for action and result input的错误很常见,那是没有配置出错时的默认视图,出现这类现象,你可以检查如下几个方面:1、页面中是否有重名的控件,就是说页面中的控件或隐藏域中有相同名字的控件,而它们在Action中又给引用到。其中把控件放在中尤为常见。2、return的视图在配置文件中是否存在,建议打开文件后用搜索,有时名字长点,英语字...

神奇的特征向量_weixin_34267123的博客-程序员秘密

为什么80%的码农都做不了架构师?&gt;&gt;&gt; ...

随便推点

软件架构设计_春水煎茶的博客-程序员秘密

什么是软件架构前言:软体设计师中有一些技术水平较高、经验较为丰富的人,他们需要承担软件系统的架构设计,也就是需要设计系统的元件如何划分、元件之间如何发生相互作用,以及系统中逻辑的、物理的、系统的重要决定的作出。在很多公司中,架构师不是一个专门的和正式的职务。通常在一个开发小组中,最有经验的程序员会负责一些架构方面的工作。在一个部门中,最有经验的项目经理会负责一些架构方面的工作。但是,越来越多的公司体

谈谈我的学习工作经历,自学linux去中兴上班_普通网友的博客-程序员秘密

工程师故事+关注  作为一个新人,怎样学习嵌入式Linux?被问过太多次,特写这篇文章来回答一下。在学习嵌入式Linux之前,肯定要有C语言基础。汇编基础有没有无所谓(就那么几条汇编指令,用到了一看就会)。C语言要学到什么程度呢?越熟当然越好,不熟的话也要具备基本技能。比如写一个数组排序、输入数字求和什么的。学C语言唯一的方法是多写程序多练习,编译出错没关系,自己去解决;执行出错没关系,自己去分析。以前我是用VC来练习C语言的,经常去尝试着写一些C语言竞赛的题目。它们是纯C、纯数学、纯逻辑的题目,不涉

记录一下最近接触到的一些奇奇怪怪的东西_weixin_30567471的博客-程序员秘密

昨天晚上看了一下熟练剖分的划分部分。。我觉得很有道理啊http://blog.csdn.net/dyx404514/article/details/8718249这篇博客写的。。太他妈好了。。仔细看看!然后我一定要学会单调栈。。qls说的卡时冲暴力的技巧。。近似花式怼的技巧还有一个成环序列的遍历技巧。。复制两份就好了。。然后还有ST表还有倍增的学习。。gcd与fib...

Linux 内核打印寄存器_打印寄存器地址_raoxu_1154492168的博客-程序员秘密

linux 内核打印寄存器打印寄存器地址,需要ioremap,例如:printk(" reg: 0x%x \n", readl(ioremap(0x120c0020, 1)));

灯塔aoi--地图视野处理_吓人的鸟的博客-程序员秘密_aoi tower

参考:http://blog.codingnow.com/2012/03/dev_note_13.html

推荐文章

热门文章

相关标签