Spring Boot 实战 :入门篇,字节跳动架构师面试

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

org.jdom

jdom2

2.0.6

org.springframework.boot

spring-boot-maven-plugin

然后再配置 application.properties 这个地方也有朋友喜欢用 yml 但是不巧这里就先只配置了 properties 的

自定义端口号 默认为 8080

server.port = 8080

添加 MySQL 数据库配置 127.0.0.1 作用和 localhost 一样

spring.datasource.url=jdbc:mysql://127.0.0.1:3306/boot_dome?serverTimezone=UTC&characterEncoding=UTF-8&useUnicode=true

用户名

spring.datasource.username=root

密码

spring.datasource.password=root

驱动

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

Thymeleaf 配置 模板支持 HTML XML Text JavaScript

spring.thymeleaf.mode=HTML5

编码,可不用配置

spring.thymeleaf.encoding=utf-8

内容类别,可不用配置

spring.thymeleaf.content-type=text/html

开发配置为 false 避免修改模板还要重启服务器

spring.thymeleaf.cache=false

配置模板路径,默认是 templates 可以不用配置

spring.thymeleaf.prefix=classpath:/templates/

这俩都配置好了之后,最起码可以保证项目能运行了。。哦哦哦不对。。还有一个地方

也是最重要的一部分!!!就是我们项目的主类!!一般新建的项目是这个样子的

然后我们再给他加上几个注解:

@ComponentScan(basePackages = “com.cs.mybatis.*”) // 扫描主程序文件

@MapperScan(“com.cs.mybatis.mapper”) // 扫描这个包下的 Mapper 文件

@ServletComponentScan // 使用该注解后,Servlet Filter Listener 可以直接通过

最后建一个测试类,测试一下是否可以访问成功,写好测试方法之后,点击右上角绿色的三角按钮启动,上边也介绍了,SpringBoot 有内置的 Tomcat 所以不用我们来配置

/**

  • @ClassName TestController

  • @Author linluochen

  • @Date 2019/4/19 16:09

  • @Version 1.0

**/

@Controller // 声明这是一个 Controller 表示此类用于负责处理 Web 请求

public class TestController {

@RequestMapping(“Test”) // 如果参数链接的请求的参数相同则调用此方法

@ResponseBody // 表示这个的返回值只一个文本不是一个视图路径 通常用于接收 AJAX 请求

public String Test(){

System.out.println(“来了老弟?”);

return “Hello World”;

}

}

页面输出结果为,同时查看控台也会有提示,这里就不贴图了。。

到这里,第一部分搭建项目就算完成了下面就是集成 MyBatis 进行增删改查

----------------------------------------------------------- 分界线 -----------------------------------------------------------------------

首先我们右键 New 一个 Package 包

然后创建好,model,mapper,service,serviceimpl 大概结构就是这个样子

model 用来存放实体类

mapper 和 service 用来放接口

serviceimpl 业务逻辑层,简单来说就是实现接口业务的地方

首先,现在数据库创建一个表:

create table teacher(

id int(11) primary key auto_increment, // 主键,自增

name varchar(30) ,

age int(11)

)

然后创建 Model 层:

package com.cs.mybatis.model;

import java.io.Serializable;

import javax.persistence.Column;

import javax.persistence.Id;

import javax.persistence.Table;

import lombok.Data;

import lombok.EqualsAndHashCode;

@Data

@EqualsAndHashCode(callSuper=false)

@Table(name=“teacher”) // 数据库名对应

public class Teacher implements Serializable {

// 序列化

private static final long serialVersionUID = 1L;

/**

  • ID

*/

@Id // 声明主键

@Column(name = “id”) // 与数据库字段名对应

private Integer id;

/**

  • 名字

*/

@Column(name = “name”)

private String name;

/**

  • 年龄

*/

@Column(name = “age”)

private Integer age;

public Teacher(){

}

public Teacher(

Integer id

){

this.id = id;

}

public void setId(Integer id) {

this.id = id;

}

public Integer getId() {

return this.id;

}

public void setName(String name) {

this.name = name;

}

public String getName() {

return this.name;

}

public void setAge(Integer age) {

this.age = age;

}

public Integer getAge() {

return this.age;

}

}

Mapper 层,这个地方我们集成了一下 Tk_MyBatis 相当于一个持久层 API 用过 Jpa 的朋友应该知道这个是啥意思,一般不是特别复杂的 sql 就不用在 Mapper 层写了,Tk 就可以搞定,当然如果是复杂的 sql 例如多表联合查询等还是要在Mapper操作的,如果实在不懂用法的话,可以给我留言评论,或者加我QQ,我会在最底部留下的

想了解详细用法的朋友可以看官方文档:https://github.com/abel533/Mapper/wiki/6.example 这里我们不做过多的介绍

package com.cs.mybatis.mapper;

import com.cs.mybatis.base.BaseMapper;

import com.cs.mybatis.model.Teacher;

import org.springframework.stereotype.Component;

@Component

public interface TeacherMapper extends BaseMapper { // 这个地方我们调用的 Tk_MyBatis 持久层 API

}

Service 层,这个就照常写就可以了

/*

  • Powered By [rapid-framework]

  • Web Site: http://www.rapid-framework.org.cn

  • Google Code: http://code.google.com/p/rapid-framework/

*/

package com.cs.mybatis.service;

import com.cs.mybatis.model.Teacher;

import java.util.List;

public interface TeacherService{

/**

  • @title: 查询全部

  • @auther: linluochen

  • @date: 2019/5/5 10:28

*/

List selectAll();

/**

  • @title: 增加

  • @param: teacher

  • @auther: linluochen

  • @date: 2019/5/5 10:30

*/

Integer insertSelective(Teacher teacher);

}

ServiceImpl 实现类,这个地方调用我们的 Mapper 虽然我们 Mapper 没有写东西,但是由于我们的 Mapper 继承了 Tk_MyBatis 里面的属性,所以可以直接调用简单的单表查询的方法

/*

  • Powered By [rapid-framework]

  • Web Site: http://www.rapid-framework.org.cn

  • Google Code: http://code.google.com/p/rapid-framework/

*/

package com.cs.mybatis.service.impl;

import com.cs.mybatis.mapper.TeacherMapper;

import com.cs.mybatis.model.Teacher;

import com.cs.mybatis.service.TeacherService;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Service;

import java.util.List;

@Service

public class TeacherServiceImpl implements TeacherService {

@Autowired // 自动装配 Bean

TeacherMapper teacherMapper;

/**

  • @title: 查询全部

  • @auther: linluochen

  • @date: 2019/5/5 10:25

*/

@Override

public List selectAll() {

return teacherMapper.selectAll();

}

/**

  • @title: 新增

  • @param: teacher

  • @auther: linluochen

  • @date: 2019/5/5 10:25

*/

@Override

public Integer insertSelective(Teacher teacher) {

return teacherMapper.insertSelective(teacher);

}

}

写完这些之后,我们去测试一下能不能用,在左侧有一个 test 文件夹,然后打开,如下图

打开后在里面写入要测试的方法,这个类呢,是我们的测试类,所有的可执行操作都可以在这个里面进行测试,不过多解释,注解已经写得很清楚了,然后写完之后运行我们写的测试方法,在左侧会有一个绿色的三角标志,然后点击运行

package com.cs.mybatis;

import com.cs.mybatis.model.Teacher;

import com.cs.mybatis.service.TeacherService;

import org.junit.Test;

import org.junit.runner.RunWith;

import org.springframework.boot.test.context.SpringBootTest;

最后

由于篇幅有限,这里就不一一罗列了,20道常见面试题(含答案)+21条MySQL性能调优经验小编已整理成Word文档或PDF文档

MySQL全家桶笔记

还有更多面试复习笔记分享如下

Java架构专题面试复习

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

com.cs.mybatis.model.Teacher;

import com.cs.mybatis.service.TeacherService;

import org.junit.Test;

import org.junit.runner.RunWith;

import org.springframework.boot.test.context.SpringBootTest;

最后

由于篇幅有限,这里就不一一罗列了,20道常见面试题(含答案)+21条MySQL性能调优经验小编已整理成Word文档或PDF文档

[外链图片转存中…(img-7t9qwz1q-1713648654570)]

还有更多面试复习笔记分享如下

[外链图片转存中…(img-Qsofriaj-1713648654570)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-dh9yMiJR-1713648654571)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 12
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值