面试问题11

1.redission如果客户端挂了,看门狗还会续期锁吗?

不会续期,等到过期时间自动释放锁,让其他客户端可以获取到锁。

2.rocketmq怎么保证消息不丢失?

2.1.使用同步的方式发送消息或者有回调的方式发送消息,确认本地的事务没有异常。

java 复制代码
SendResult sendResult = producer.send(msg,20*1000);
//异步发送,生产者另起一个线程等待broker确认,收到Broker确认之后直接触发回调方法。消息安全和效率之间比较均衡,但是会加大客户端的负担。
producer.send(msg,new SendCallback(){
	@Override
	public void onSuccess(SendResult sendResult){
		//do something
	}
	
	@Override
	public void onException(Throwable e){
		//do something
	}
})

2.2.broker 同步刷盘

2.3.消费者手动提交offset。

3.volatile是什么意思,有什么用?

4.一个表数据量太大如何处理?

4.1.加索引

4.2 表分区

java 复制代码
CREATE TABLE sales (
    id INT NOT NULL,
    amount DECIMAL(10, 2) NOT NULL,
    order_date DATE NOT NULL,
    PRIMARY KEY (id, order_date)
) 
PARTITION BY RANGE (YEAR(order_date)) (
    PARTITION p2020 VALUES LESS THAN (2021),
    PARTITION p2021 VALUES LESS THAN (2022),
    PARTITION p2022 VALUES LESS THAN (2023),
    PARTITION pFuture VALUES LESS THAN MAXVALUE
);

4.3分库分表。

4.4 存储在es或者使用tidb

5.java agent如何使用?

6 数据库如何优化?

6.1.先确认表使用有没有问题,例如索引正确建立,使用。避免索引失效场景

6.2 优化数据库配置

6.3 优化硬件配置,例如硬盘换成固态硬盘。

7.list抽出id,name组成新的map如何操作

java 复制代码
  Map<Integer, String> idToNameMap = people.stream()
            .collect(Collectors.toMap(Person::getId, Person::getName));
  1. 有一个成绩表,查出每个班级的前三名
    8.1
java 复制代码
select *from (
SELECT
	s.*,
	ROW_NUMBER() over ( PARTITION BY s.c_id ORDER BY s.s_score DESC ) AS ranks 
FROM
	score s ) a where a.ranks<=3
	

这里 使用了窗口函数,根据c_id分组然后按score排序,得到每个学生的排名,然后再用子查询查出排名,这里如果不用子查询会报错,必须再包一层。

结果如上图

8.2

java 复制代码
SELECT
	s1.s_id,s1.c_id,s1.s_score ,count(1)from score s1 left join 
(select distinct s.c_id,s.s_score from score s) s2  on s1.c_id=s2.c_id and s1.s_score<s2.s_score
GROUP BY
	s1.c_id,
	s1.s_id,
	s1.s_score having count(s1.c_id)<3 order by s1.c_id asc,s1.s_score desc

思路是,通过left join 找到 s1中比s2还小的条数有多少条,小于3条则证明,该成绩是排名前三的,

但是这种写法分数相同的算并列/。

相关推荐
.Hypocritical.6 分钟前
数据结构笔记——链表成环/反转 + 有序二叉树(BST)构建、遍历、删除
java·数据结构
云飞云共享云桌面10 分钟前
搭建10人SolidWorks云设计环境:云飞云在非标自动化工厂的实测方案
运维·服务器·网络·数据库·自动化·电脑
A-刘晨阳13 分钟前
关键基础设施安全底座:自主可控时序大模型TimechoAI的国产化实践与深度时序分析能力
大数据·数据库·安全·时序数据库
深盾科技_Virbox14 分钟前
Virbox Protector 从何而来:深盾科技的软件保护演进
运维·数据库·科技
只会写代码17 分钟前
一套开箱即用实体反射Lambda链式工具,彻底告别原生反射样板代码
java·程序员·源码
AI人工智能+电脑小能手17 分钟前
【大白话说Java面试题 第151题】【06_Spring篇】第11题:说一下 Spring Bean 的生命周期?
java·开发语言·后端·spring·面试
骑士雄师24 分钟前
java面试题:jvm ,mybatis
java·jvm·mybatis
广州浮点FLOATLIC30 分钟前
Creo 许可证利用率怎么优化:制造企业该先看共享规则,还是先看模块占用结构
java·开发语言
2601_9624408441 分钟前
计算机毕业设计之jsp教室管理系统
java·开发语言·笔记·分布式·算法·课程设计·推荐算法
禅思院2 小时前
AI对话前端从入门到崩溃:一个长对话引发的五层优化战争【引子】
前端·面试·架构