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;
启动类重新启动
更新成功