技术标签: spring boot java mysql
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
);
参考mysql与java的驼峰匹配规则创建bean
示例 user_name =>userName 遇到下划线后面单词首字母大写
选择当前包
最后的.为类之前的为包名
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;
}
当前项目结构图
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>
同上面创建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);
}
}
控制层代码
爆红地方alt+回车创建service
注意是创建service接口(不过没业务可以省略,这里就不省略了以后有业务一定是按照这种模式开发)
回车下一步(多模块记得看看下面路径是不是自己模块的路径以防创建到别的模块中)
结构图
继续到控制层把错误解决(alt+回车快速创建方法 没有业务逻辑所以比较快)
实现接口方法
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);
}
}
生成方法
可以看见业务层实现类还是有冒红的警告(是因为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);
}
}
# 端口号默认就是8080
server:
port: 8080
spring:
datasource:
driver-class-name: com.mysql.jdbc.Driver
# 此处省略了本机如果是远程的话需要手动指定ip地址
url: jdbc:mysql:///microtest
username: root
password: root
# 德鲁伊数据源
type: com.alibaba.druid.pool.DruidDataSource
# mybatis
mybatis:
# 找到持久化的xml配置文件
mapper-locations: classpath:mappers/*.xml
# 别名包
type-aliases-package: cn.zlf.domain
configuration:
# 驼峰
map-underscore-to-camel-case: true
# 二级缓存
cache-enabled: false
创建在核心配置文件同级 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模板 直接创建就好了(模板为你设置的名字,创建另外取名见名思意)
启动报错看一下问题 说
很明显了xml有问题查了下是路径不正确(命名空间我没设置对要设置到你的接口mapper的路径还有类型匹配要找到对应的bean)
重新启动成功
根据自己的请求跟端口号匹配 后面拼接需要的参数(数据库要有数据才可以查得到之前创建数据库后可以自己添加数据进去)
最终结果
测试路径
GET http://localhost:8080/user/points?userId=1
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;
启动类重新启动
更新成功
原文链接:https://www.cnblogs.com/xiaoxiaoyihan/p/5692133.htmlDOM1级主要定义了文档的底层结构,并提供了基本的查询操作的API,总体而言这些API已经比较完善,我们可以通过这些API完成大部分的DOM操作。然而,为了扩展DOM API的功能,同时进一步提高DOM操作的效率,DOM扩展也不断被提出和采纳。对DOM的扩展主要有两部分:Selecto...
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
No result defined for action and result input的错误很常见,那是没有配置出错时的默认视图,出现这类现象,你可以检查如下几个方面:1、页面中是否有重名的控件,就是说页面中的控件或隐藏域中有相同名字的控件,而它们在Action中又给引用到。其中把控件放在中尤为常见。2、return的视图在配置文件中是否存在,建议打开文件后用搜索,有时名字长点,英语字...
H3C AP 升级 胖AP刷瘦AP WAC 上线配置 WA2620i-AGN
为什么80%的码农都做不了架构师?>>> ...
什么是软件架构前言:软体设计师中有一些技术水平较高、经验较为丰富的人,他们需要承担软件系统的架构设计,也就是需要设计系统的元件如何划分、元件之间如何发生相互作用,以及系统中逻辑的、物理的、系统的重要决定的作出。在很多公司中,架构师不是一个专门的和正式的职务。通常在一个开发小组中,最有经验的程序员会负责一些架构方面的工作。在一个部门中,最有经验的项目经理会负责一些架构方面的工作。但是,越来越多的公司体
工程师故事+关注 作为一个新人,怎样学习嵌入式Linux?被问过太多次,特写这篇文章来回答一下。在学习嵌入式Linux之前,肯定要有C语言基础。汇编基础有没有无所谓(就那么几条汇编指令,用到了一看就会)。C语言要学到什么程度呢?越熟当然越好,不熟的话也要具备基本技能。比如写一个数组排序、输入数字求和什么的。学C语言唯一的方法是多写程序多练习,编译出错没关系,自己去解决;执行出错没关系,自己去分析。以前我是用VC来练习C语言的,经常去尝试着写一些C语言竞赛的题目。它们是纯C、纯数学、纯逻辑的题目,不涉
昨天晚上看了一下熟练剖分的划分部分。。我觉得很有道理啊http://blog.csdn.net/dyx404514/article/details/8718249这篇博客写的。。太他妈好了。。仔细看看!然后我一定要学会单调栈。。qls说的卡时冲暴力的技巧。。近似花式怼的技巧还有一个成环序列的遍历技巧。。复制两份就好了。。然后还有ST表还有倍增的学习。。gcd与fib...
linux 内核打印寄存器打印寄存器地址,需要ioremap,例如:printk(" reg: 0x%x \n", readl(ioremap(0x120c0020, 1)));
参考:http://blog.codingnow.com/2012/03/dev_note_13.html
RatingBar、SeeBar控件