面试复盘(立讯)

1.spingboot mvc每一层的常用注解

感觉有问题很多注解都是sping的,不是sping boot的.

controller :

@Controller 对应 Spring MVC 控制层;

package org.springframework.stereotype;应该是sping的注解

@ResponseBody 不返回页面而是返回json格式的数据

(package org.springframework.web.bind.annotation;应该是sping web的注解)

@RestController 等于@ResponseBody +@Controller

package org.springframework.web.bind.annotation;应该是sping web的注解

@RequestMapping 用来处理 url 请求地址映射的注解

(package org.springframework.web.bind.annotation;应该是sping web的注解)

@RequestBody 读取 Request 请求(可能是 POST,PUT,DELETE,GET 请求)的 body 部分并且Content-Type 为 application/json 格式的数据,接收到数据之后会自动将数据绑定到 Java 对象上去。

(package org.springframework.web.bind.annotation;应该是sping web的注解)

@RequestParam 获取请求体中的查询参数

(package org.springframework.web.bind.annotation;应该是sping web的注解)

@PathVariable 获取请求体中的路径参数

(package org.springframework.web.bind.annotation;应该是sping web的注解)

@GetMapping @PostMapping @PutMapping @DeleteMapping

(package org.springframework.web.bind.annotation;应该是sping web的注解)

@Autowired 自动注入

(package org.springframework.beans.factory.annotation;应该是sping的注解)

@Qualifier 配合@Autowired使用,用于指定注入的Bean的名称或ID

(package org.springframework.beans.factory.annotation;应该是sping的注解)

@Scheduled(定时任务)

(package org.springframework.scheduling.annotation;应该是sping的注解)

 @Cacheable 缓存

(package org.springframework.cache.annotation;应该是sping的注解)

Service 

@Service 对应 Spring MVC 业务层;

package org.springframework.stereotype;应该是sping的注解

@Autowired 自动注入

(package org.springframework.beans.factory.annotation;应该是sping的注解)

@Qualifier 配合@Autowired使用,用于指定注入的Bean的名称或ID

(package org.springframework.beans.factory.annotation;应该是sping的注解)

@Transactional 开启事务

(package org.springframework.transaction.annotation;应该是sping的注解)

@Async 异步执行

(package org.springframework.scheduling.annotation;应该是sping的注解)

Mapper:

@Mapping(可以不加)

(package org.springframework.web.bind.annotation;应该是sping web的注解)

Domain:

@Id 主键

(package org.springframework.data.annotation;应该是sping的注解)        

ps:

@ControllerAdvice用在类上,声明一个控制器建言,它也组合了@Component注解,会自动注册为Spring的Bean。@ControllerAdvice注解将作用在所有Controller层的方法上。配合@ExceptionHandler注解,进行全局异常处理。

(package org.springframework.web.bind.annotation;应该是sping web的注解)

@ExceptionHandler用在方法上定义全局处理,通过他的value属性可以过滤拦截的条件:@ExceptionHandler(value=Exception.class)–表示拦截所有的Exception。

(package org.springframework.web.bind.annotation;应该是sping web的注解)

2.是否使用过自定义注解

实际工作中哪些地方用到了自定义注解? | Javaᶜⁿ 面试突击

3.jdk1.8新特性 Lambda 表达式

lambda表达式,也被称为闭包,它是推动Java8发布的最重要新特性。lambda允许把函数作为一个方法的参数(函数作为参数传递进方法中),使用Lambda表达式可以使代码变的更加简洁紧凑。
优点:
代码更加简洁
减少匿名内部类的创建,节省资源
使用时不用去记忆所使用的接口和抽象函数
缺点:
不易于后期维护,必须熟悉lambda表达式和抽象函数中参数的类型
可读性差
若不用并行计算,很多时候计算速度没有比传统的for循环快。(并行计算有时需要预热才显示出效率优势)
不容易调试。
若其他程序员没有学过lambda表达式,代码不容易让其他语言的程序员看懂。
 

4.存储过程怎么创建 创建语句(oracle)

create or replace procedure 存储过程名称

  as  //声明 

  

  begin // 执行 

  

  exception//存储过程异常 

  

  end ;

5.存储过程和函数区别

储存过程可以有返回值也可以无返回值。函数必须有返回值。

存储过程的实现比较复杂,而函数的实现比较有针对性。

储存过程可以输入输出参数,而函数只可以输入参数。

过程允许在其中选择以及DML语句,而函数只可以在其中select语句。

可以在存储过程中调用函数,不可以在函数中调用存储过程。

6.oracle执行计划中表的关联方式

Nest Loop 嵌套循环 (大小表)
Sort Merge 排序合并 (添加索引+两张大表)
Hash Join 哈希 (内联)

  • Nested Loop:
    对于被连接的数据子集较小的情况,Nested Loop是个较好的选择。Nested Loop就是扫描一个表(外表),每读到一条记录,就根据Join字段上的索引去另一张表(内表)里面查找,若Join字段上没有索引查询优化器一般就不会选择 Nested Loop。在Nested Loop中,内表(一般是带索引的大表)被外表(也叫“驱动表”,一般为小表——不仅相对其它表为小表,而且记录数的绝对值也较小,不要求有索引)驱动,外表返回的每一行都要在内表中检索找到与它匹配的行,因此整个查询返回的结果集不能太大(大于1 万不适合)。Nested Loop适用于结果集很小(一般要求小于一万条),并且内表在Join字段上建有索引(这点非常非常非常重要)。

  • Hash Join:
    Hash Join是做大数据集连接时的常用方式,优化器使用两个表中较小(相对较小)的表利用Join Key在内存中建立散列表,然后扫描较大的表并探测散列表,找出与Hash表匹配的行。
    这种方式适用于较小的表完全可以放于内存中的情况,这样总成本就是访问两个表的成本之和。但是在表很大的情况下并不能完全放入内存,这时优化器会将它分割成若干不同的分区,不能放入内存的部分就把该分区写入磁盘的临时段,此时要求有较大的临时段从而尽量提高I/O 的性能。它能够很好的工作于没有索引的大表和并行查询的环境中,并提供最好的性能。大多数人都说它是Join的重型升降机。Hash Join只能应用于等值连接(如WHERE A.COL3 = B.COL4),这是由Hash的特点决定的

  • Merge Join:
    通常情况下Hash Join的效果都比排序合并连接要好,然而如果两表已经被排过序,在执行排序合并连接时不需要再排序了,这时Merge Join的性能会优于Hash Join。Merge join的操作通常分三步:
      1. 对连接的每个表做table access full;
      2. 对table access full的结果进行排序。
      3. 进行merge join对排序结果进行合并。
    在全表扫描比索引范围扫描再进行表访问更可取的情况下,Merge Join会比Nested Loop性能更佳。当表特别小或特别巨大的时候,实行全表访问可能会比索引范围扫描更有效。Merge Join的性能开销几乎都在前两步。Merge Join可适于于非等值Join(>,<,>=,<=,但是不包含!=,也即<>)

7.有时候执行慢,会手动更改表和表之间的连接方式,Nest Loop 嵌套循环和 Hash Join 哈希 怎么选择?

参考:sql 算法 : Nested Loop,Hash Join,Merge Join介绍 - 不会游泳的鱼~~ - 博客园 (cnblogs.com)

8.报表查询慢 怎么优化

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值