boot 笔记
第一步新建工程,导包,由于boot的数据库框架是用mybtis -paus,所以关于数据库系统那儿不用色选mybatis ,需要重新maven导包
完整导包以下人容:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.3</version>
</parent>
<groupId>com.example</groupId>
<artifactId>demo_boot</artifactId> <properties>
<version>0.0.1-SNAPSHOT</version>
<java.version>1.8</java.version>
</properties> <dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency> <dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.2</version>
</dependency> <dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.2.11</version>
</dependency> <dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency> <dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.3.5.RELEASE</version>
</plugin>
</plugins>
</build> </project>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.2</version>
</dependency>

<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.2.11</version>
</dependency>
//下面那个组件目的是完成实体不需要set get,只需要加一个注解@data
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>

第二步配,配置服务器端口,数据库 配置mybatis 的id 自增算法,还要配置日志系统不要显示全部信息,

server:
port: 80
//配置数据库地址
spring:
datasource:
druid:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/xsytest
username: root
password: 142857
//配置表前缀
mybatis-plus:
global-config:
db-config:
table-prefix: tbl_
//以下配配置id的自增算法
id-type: auto
//配置日志系统的显示内容。
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

第三步,编写dao数据库层,这儿只要写接口就好,先编写一个实体类,比如关于图书的表,就需要新建一个给数据库表相同字段的实体类,

import lombok.Data;
import lombok.Getter;

//使用lombok 就可以不在set get 设置了
@Data
public class Book {
private Integer id;
private String type;
private String name;
}

传统配置方法一个方法对应一个sql查询语句;

@Mapper
public interface bookDao {
@Select("select * from tbl_book where id = #{id}")
Book getById(Integer id);
.........................................

传统定法太费时,mybatis-paus 为我们写好了全部方法,可能继承一个方法
@Mapper
public interface bookDao extends BaseMapper<Book> {}
这样常见的增删改方法就不用写了,可以在service层调用大部份数据库相关操作的方法.

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++=

关于service,层取名一定要给业务相关,先定义接口,然后新建impl包,实现方法类:
举例如下:

import java.util.List;

public interface BookService {
boolean save(Book book);
boolean update(Book book);
boolean delete(Integer id);
Book getById(Integer id);
List<Book> getAll();
IPage<Book> getByPage(int currentPage, int pageSize);

}
++++++++++++++++++然后实现类实现上面方法:++++++++++++++++++++++++++++++++++++++++++++++++

import java.util.List;
@Service
public class BookServiceimpl2 implements BookService {

@Autowired
private bookDao bookDao;

@Override
// 业务层都是逻辑规则,所以用返回布尔来判断
public boolean save(Book book) {

return bookDao.insert(book) > 0;
}

@Override
public boolean update(Book book) {

return bookDao.updateById(book) >0;

}

@Override
public boolean delete(Integer id) {
return bookDao.deleteById(id) > 0;
}

@Override
public Book getById(Integer id) {
return bookDao.selectById(id);
}

@Override
public List<Book> getAll() {
return bookDao.selectList(null);
}
@Override
public IPage<Book> getByPage(int currentPage, int pageSize) {
IPage page = new Page(currentPage,pageSize);
bookDao.selectPage(page,null);
return page;
}
}

+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
由于都是操作增改,mybatis 帮我们也提供了更多方法,就边业务层都是可以不写的,但是很多方法不能解决实际场景时,可以重新写,但尽量不要改写框架也有的
以下是示例,

第一步定义业务层接口

public interface IBookService extends IService<Book> {

boolean saveBook(Book book);
boolean modify(Book book);
boolean delect(Integer id);
//Book select(Integer id);
IPage<Book> getPage(int currentpage, int pagesize) ;
}

第二步实现具体业务层

@Service
public class IbookServiceimpl extends ServiceImpl<bookDao, Book> implements IBookService { @Autowired
private bookDao bookDao; @Override
public boolean saveBook(Book book) {
return bookDao.insert(book) > 0;
} @Override
public boolean modify(Book book) {
return bookDao.updateById(book) >0;
} @Override
public boolean delect(Integer id) {
return bookDao.deleteById(id) > 0;
} @Override
public IPage<Book> getPage(int currentpage, int pagesize) {
// Page page = new Page(currentpage, pagesize);
// bookDao.selectPage(page, null);
// return page; IPage page = new Page(currentpage,pagesize);
bookDao.selectPage(page,null);
return page;
} //
// @Override
// public Book select(Integer id) {
// return bookDao.selectById(id);
//
// }
}

mybatis-paus 自动构建的业务层方法操作数据库方法与dao 有点出入

到此为止,整个底层,业务层建 那了可以编写测试类,测试类的目录要和开发的目录一样
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

dao测试文件

@SpringBootTest
public class bookDaotext { @Autowired
private bookDao bookDao; @Test
void testGetById(){
// System.out.println(bookDao.selectById(3));
// System.out.println(bookDao.selectList(null));
} @Test
void testGetPage(){
IPage page = new Page(1,6);
bookDao.selectPage(page, null);
// 通过以下的方法可以获取当前页,共几页等前端需要的数据
System.out.println(page.getCurrent());
System.out.println(page.getSize());
System.out.println(page.getTotal());
System.out.println(page.getPages());
System.out.println(page.getRecords());
} @Test
// 按条析查询
void testGetBy(){
QueryWrapper<Book> qw = new QueryWrapper<>();
// qw.eq,qw.??所有条件方法都在qw上
qw.like("name", "rrrr");
bookDao.selectList(qw);
}
//条件查询方法中强制指定参数的方法
void testGetBy2(){
LambdaQueryWrapper<Book> lqw = new LambdaQueryWrapper<Book>();
String name = "Spring";
// 为了防止参数为空,方法一
// if(name != null ) lqw.like(Book::getName,name);
// 方法二
lqw.like(name !=null,Book::getName,name);
bookDao.selectList(lqw); }
业务层测试文件

@SpringBootTest
public class BookServiceTest {
@Autowired
private BookService bookService; @Test
void testGetById(){
System.out.println( "运行结果为"+bookService.getById(4));
} // 测保存方法
@Test
void testSave(){
Book book = new Book();
book.setName("黄金枝");
book.setType("name_vv");
bookService.save(book);
} @Test
void testUpdate(){
Book book = new Book();
book.setId(16);
book.setName("kk151515");
book.setType("u151515");
bookService.update(book); }

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

然后编写控制层。
import java.util.List;
@RestController
@RequestMapping("/books")
public class BookController {
@Autowired
private IBookService bookService;
@GetMapping
public List<Book> getAll(){
return bookService.list();
}
@PostMapping
public Boolean save(@RequestBody Book book){
return bookService.save(book);
}
@PutMapping
public Boolean update(@RequestBody Book book){
return bookService.modify(book);
}
@DeleteMapping("{id}")
public boolean delect(@PathVariable Integer id){
return bookService.delect(id);
}
@GetMapping("{id}")
public Book getById(@PathVariable Integer id){
return bookService.getById(id);
}
@GetMapping("/{currentpage}/{pagesize}")
public IPage<Book> getPage(@PathVariable int currentpage,@PathVariable int pagesize){
return bookService.getPage(currentpage, pagesize);
}

}
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

由于前端交互数据需要统一数据,这儿需要专门定义一个类用来返回数据,将数据封装后返回:
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
@Data
public class R {
private Boolean flag;
private Object data;
public R(){}
public R(Boolean flag){
this.flag = flag;
}
public R(Boolean flag, Object data){
this.flag = flag;
this.data = data;
}
}
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

@RestController
@RequestMapping("/books")
public class BookController {
@Autowired
private IBookService bookService;
@GetMapping
public R getAll(){
return new R(true,bookService.list());
// return bookService.list();
}
@PostMapping
public R save(@RequestBody Book book){
return new R(bookService.save(book));
}

@PutMapping
public R update(@RequestBody Book book){

return new R(bookService.modify(book));
}
@DeleteMapping("{id}")
public R delect(@PathVariable Integer id){
return new R(bookService.delect(id));
// return bookService.delect(id);
}
@GetMapping("{id}")
public R getById(@PathVariable Integer id){
return new R(true, bookService.getById(id));
// return bookService.getById(id);
}
@GetMapping("/{currentpage}/{pagesize}")
public R getPage(@PathVariable int currentpage,@PathVariable int pagesize){
return new R(true, bookService.getPage(currentpage, pagesize));

// return bookService.getPage(currentpage, pagesize);
}

}
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++


springboot,简要记录,方便复习,的更多相关文章

  1. Springboot学习记录1--概念介绍以及环境搭建

    摘要:springboot学习记录,环境搭建: 官方文档地址:https://docs.spring.io/spring-boot/docs/current-SNAPSHOT/reference/ht ...

  2. 【原】【BG】-一次虚拟化环境实践简要记录

    部分涉及到Linux.Nginx.tomcat.MySQL等的点滴操作记录,时间长了,就忘掉了,偶尔整理一下操作的history,就此简要备份一下: [原][BG]-一次虚拟化环境实践简要记录: ht ...

  3. pt-align的用法简要记录

    pt-align的用法简要记录 1.pt-align 功能:将其它工具的输出按列对齐用法:pt-align [FILES]如果没有指定文件,则默认读取标准输入的内容. 2.例如: [root@dbte ...

  4. SpringBoot学习记录(二)

    一. SpringBoot日志框架 SpringBoot:底层是Spring框架,Spring框架默认是用JCL(commons-logging): SpringBoot选用SLF4j和logback ...

  5. 使用SpringBoot AOP 记录操作日志、异常日志

    平时我们在做项目时经常需要对一些重要功能操作记录日志,方便以后跟踪是谁在操作此功能:我们在操作某些功能时也有可能会发生异常,但是每次发生异常要定位原因我们都要到服务器去查询日志才能找到,而且也不能对发 ...

  6. log4j配置文件简要记录

    和大多数配置文件一样,log4j配置文件也有key-value形式和xml形式.这里主要记录一下key-value的形式 我们通过配置,可以创建出Log4j的运行环境.Log4j由三个重要的组件构成: ...

  7. 一次linux问题分析原因的简要记录

    1. 这边功能测试 一个linux服务器 4c 16g的内存 发现总是出现异常. dotnet run 起来的一个 程序 总是会被killed 现象为: 2. 一开始怀疑是 打开的文件描述符过多 引起 ...

  8. SpringBoot 常见问题记录

    问题一 Error starting ApplicationContext. To display the auto-configuration report re-run your applicat ...

  9. /proc/xxx/maps简要记录

    定位内存泄漏基本上是从宏观到微观,进而定位到代码位置. 从/proc/meminfo可以看到整个系统内存消耗情况,使用top可以看到每个进程的VIRT(虚拟内存)和RES(实际占用内存),基本上就可以 ...

  10. SpringBoot学习记录(一)

    一.SpringBoot入门 1.SpringBoot简介 简化Spring应用开发的一个框架:整个Spring技术栈的一个大整合:J2EE开发的一站式解决方案: SpringBoot的优点: (1) ...

随机推荐

  1. MybatisPlus对Mysql数据库关键字作为列名的处理--SQLSyntaxErrorException: You have an error in your SQL syntax;

    说明: 在设计数据库时,使用mysql关键字作为列名(比如order用于排序),就会报错:java.sql.SQLSyntaxErrorException: You have an error in ...

  2. 【4】python读写文件操作---详细讲解!

    相关文章: 全网最详细超长python学习笔记.14章节知识点很全面十分详细,快速入门,只用看这一篇你就学会了! [1]windows系统如何安装后缀是whl的python库 [2]超级详细Pytho ...

  3. Go语言的100个错误使用场景(11-20)|项目组织和数据类型

    目录 前言 2. Code and project organization 2.11 没有使用函数式选项模式(#11) 2.12 项目缺乏组织(#12) 2.13 创建公共设施包(#13) 2.14 ...

  4. React核心概念与JSX

    React概况 React是一个只用来写HTML的UI页面的JS库,在MVC设计模式中它只相当于View,故:它并不是一个框架(MVC架构角色设计). React组件内数据改动会自动更新到屏幕上. R ...

  5. XPath从入门到精通:基础和高级用法完整指南,附美团APP匹配示例

    XPath 通常用来进行网站.XML (APP )和数据挖掘,通过元素和属性的方式来获取指定的节点,然后抓取需要的信息. 学习 XPath 语法之前,首先了解一下一些概念. 概念介绍 节点之间的关系 ...

  6. 联想T30瘦客户机安装DoraOS体验

    硬件配置:J4125 .8G RAM. 128G ROM 联想T30台式电脑,它是一台迷你计算机,尺寸小巧玲珑,重量适中,方便携带.它的性能十分强大,能够运行各种应用程序,包括网页浏览器.视频播放器等 ...

  7. shell find 根据时间获取文件列表

    根据时间得到文件,可以使用find进行查找,支持查找: find以时间为条件查找可用选项: -amin n:查找n分钟以前被访问过的所有文件. -atime n:查找n天以前被访问过的所有文件. -c ...

  8. ABC270F 题解

    和博客园一样好的体验 思路 首先看到花最小代价使得所有点连通,果断转换成最小生成树问题. 接下来就要考虑怎么建图,首先陆地就正常连不用说,建机场和港口的代价貌似都是点权,考虑转成边权.因为一个点飞或者 ...

  9. .NET Core开发实战(第31课:APIController:定义API的最佳实践)--学习笔记

    31 | APIController:定义API的最佳实践 首先看一个传统意义上三层架构定义的 Controller [HttpPost] public Task<long> Create ...

  10. Flink-启动后无法访问WebUI界面(Flink1.16)

    问题描述 通过./bin/start-cluster.sh启动Flink程序,正常启动后无法通过浏览器访问web UI界面,http://192.168.80.133:8081. 问题原因 Flink ...