某小厂面试题

7.Spring Boot 常用注解

Spring Boot 中的常用注解有很多,比如以下这些:

  1. @SpringBootApplication:标记一个主要的 Spring Boot 应用的启动类。
  2. @Controller:将类标记为控制器,处理 HTTP 请求。
  3. @RestController:类似于 @Controller,但是它还将返回的对象自动转换为 JSON 格式。
  4. @RequestMapping:用于映射 HTTP 请求到具体的处理方法。
  5. @GetMapping、@PostMapping、@PutMapping、@DeleteMapping:用于分别处理 GET、POST、PUT、DELETE 请求。
  6. @RequestParam:用于将请求参数绑定到处理方法的参数上。
  7. @PathVariable:用于将 URL 路径变量绑定到处理方法的参数上。
  8. @RequestBody:用于将请求体绑定到处理方法的参数上。
  9. @Autowired:用于自动装配依赖关系,通过类型进行依赖注入。
  10. @Qualifier:与 @Autowired 一起使用,指定注入的具体实现。
  11. @Value:用于注入配置属性值。
  12. @Component:将类标记为 Spring 容器的组件。
  13. @Service:将类标记为服务层组件。
  14. @Repository:将类标记为数据访问层组件。
  15. @Configuration:标记类为配置类,用于定义配置项。
  16. @Bean:在配置类中使用,用于声明一个 Bean 对象。

8.#{} 和 ${} 的区别?

${} 和 #{} 在 MyBatis 中都是用于 SQL 参数替换的符号,它们的区别主要体现在以下几个方面:

  1. 功能不同:${} 是直接替换,而 #{} 是预处理;
  2. 使用场景不同:普通参数使用 #{},如果传递的是 SQL 命令或 SQL 关键字,需要使用 ${},但在使用前一定要做好安全验证;
  3. 安全性不同:使用 ${} 存在安全问题,如 SQL 注入,而 #{} 则不存在安全问题。

9.MyBatis 如何分页?

MyBatis 实现分页有两种常见的方式:

  1. 手写 SQL 进行分页:比如 MySQL 中使用 limit x offset y 即可实现分页,分页的公式是 (pageIndex-1)*pageSize;
  2. 使用分页插件 PageHelper:PageHelper 是一个开源的分页插件,基于拦截器实现。它通过拦截 Executor 的 query 方法,在执行查询前拦截并修改 SQL 语句,实现分页逻辑的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT界的一只菜鸟

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值