百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

「每日打卡」深圳35家公司JAVA面试真题-数据库篇(二)

mhr18 2024-10-09 12:22 27 浏览 0 评论

一:前言

  • 秋招将至,特意整理了之前面试过的题目分享出来,坚持每日学习、打卡,秋招Offer满满!
  • 题目会持续更新,且保证有质量,期待你的参与,一起打卡,一起进步!


二:面试题目

一: 什么是乐观锁和悲观锁,可以举例说说?

??悲观锁:
?? ??总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它解锁


?? ??传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁。就像for update,再比如Java里面的同步原语synchronized关键字的实现也是悲观锁。


??乐观锁:
?? ??顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制


?? ??乐观锁适用于多读的应用类型,这样可以提高吞吐量,像数据库提供的类似于write_condition机制,其实都是提供的乐观锁。

二: 简单介绍下什么是MVCC

?? 全称是:多版本并发控制(Multi-Version Concurrency Control) ,是现代数据库(包括 MySQL 、 Oracle 、 PostgreSQL 等)引擎实现中常用的处理读写冲突的手段, 目的在于提高数据库高并发场景下的吞吐性能。


?? 如此一来不同的事务在并发过程中, SELECT 操作可以不加锁而是通过 MVCC 机制读取指定的版本历史记录,并通过一些手段保证保证读取的记录值符合事务所处的隔离级别,从而解决并发场景下的读写冲突。


三: 常见的varchar(50),其中的50是什么含义

?? 50表达的含义是:最多存放50个字符,varchar(50)和(200)存储hello所占空间一样,但后者在排序时会消耗更多内存,因为order by col采用fixed_length计算col长度(memory引擎也一样)。在早期 MySQL 版本中, 50 代表字节数,现在代表字符数。


?? 因为varchar是变长,所以需要1-2个字节去标识这一列的长度,char, varchar类型的值,会有一个长度标识位来存值长度。


?? 当定义varchar长度小于等于255时,长度标识位需要一个字节;当大于255时,长度标识位需要两个字节。


四: int(20)中20的又有什么含义

??1、是指显示字符的长度。20表示最大显示宽度为20,但仍占4字节存储,存储范围不变


??2、不影响内部存储,只是影响带 zerofill 定义的 int 时,前面补多少个 0,易于报表展示


??3、对大多数应用没有意义,只是规定一些工具用来显示字符的个数;int(1)和int(20)存储和计算均一样


五: Drop、Truncate、Delete的有什么区别

??1、Drop: 删除数据内容和定义,并释放空间


??2、Truncate: 删除数据内容、释放空间,但不删除定义,并且重新设置索引ID从1开始,不触发Delete触发器,不能Rollback,且不能携带条件删除。


??3、Delete: 删除数据内容、不释放空间、不删除定义、可以携带条件,可以进行Rollback,效率低于Truncate,因为它相当于一行行的删除。


六: 什么是触发器、有什么作用

??它是一种特殊的存储过程,主要是用来通过事件如插入、删除来触发而被执行的。它可以强化约束,来维护数据的完整性和一致性,可以联级运算。

七: 什么是存储过程,它的优缺点

??是一个预编译的SQL语句,优点是模块化设计即只需创建一次,以后便可以在程序中多次使用。


??缺点是: 调试麻烦,移植性差、难以维护。

八: 有没有使用过视图,知道视图是什么、知道视图的使用场景是什么、使用视图的时候应该注意什么

??一、定义:
?? ??视图是一个虚拟的表(对若干个基本表的引用),具有和物理表相同的功能,可以对视图进行增、改、查操作。


??二、作用:
?? ??方便操作、增强可读性、更加的安全、数据库授权命令不能够限制到具体的行和具体的列,但是可以通过合理的创建视图,将权限限制到具体的行和列中。


??三、使用场合:

?? ??1、权限控制: 不希望用户访问表中某些敏感信息如:薪资

?? ??2、简化操作、提高效率: 关键信息来源多个表时,创建视图提取需要的信息,简化操作。


??四、注意事项
?? ??1、不能在一张或者多张关联表连接而成的视图上做同时修改两张表的操作


?? ??2、如果视图和表是一对一关系,如果没有其他约束(如:在基本表必填的字段视图没有),是可以进行增、删、改操作。


?? ??3、视图和表是一对多关系,如只修改一张表的数据,且没有其他约束,是可以进行”改”操作,但是删除和插入操作不行。


九: id作为主键,但可能不是连续增长的列,如何查询表A(id、name)中第31至40条记录

?? (一):思路
?? ?? 因为id可能不是连续增长的,无法直接通过排序然后limit获取,所以需要先找到记录的起始位置的ID。


?? (二):针对SQL Server数据库
?? ?? Select top 10 from A where id > (select max(ID) from (select top 30,id from A order by id) T) order by A


?? (三):针对如MySql这种没有top关键字的数据库,需要分步处理

?? 1、先查询到前三十条id:
?? ?? select id from A order by id limit 30

?? 2、查询到前30条数据最大的id:
?? ?? Select max(id) from (select id from A order by id limit 30)

?? 3、从大于前30条数据的ID中查找10条
?? ?? Select * from A where id > (Select max(id) from (select id from A order by id limit 30)) order by id limit 10

十: 如何通过SQL语句完成表结构和数据的复制

?? 1、create table 新的表名 select * from 旧表名(可以复制结构和数据,但是像主键这种属性无法复制)


?? 2、create tale 新表名 like 旧表名(只复制表结构,不复制数据)


?? 3、insert into 新表(可以选择复制的字段) select * from 旧表(复制字段-可选)


?? 4、select * into 新表 from 旧表 where 1=2(复制旧表结构到新表中,1=2的目的就是为了不复制表中的数据)


?? 5、select * into 新表 from 旧表(复制旧表内容到新表中)


三:下篇预告

?? 下篇的面试题目主要是关于数据库优化方面的知识,包括索引、回表、Explain关键字解析等,。


?? 欢迎大家关注,如果觉得文章对你有帮助,不要忘记一键三连哦,你的支持是我创作更加优质文章的动力,希望大家都能够早日拿到心仪的Offer,有任何面试问题可以私信我,欢迎大家投稿面试题目哦!

35家公司面试题目的大纲

相关推荐

Redis合集-使用benchmark性能测试

采用开源Redis的redis-benchmark工具进行压测,它是Redis官方的性能测试工具,可以有效地测试Redis服务的性能。本次测试使用Redis官方最新的代码进行编译,详情请参见Redis...

Java简历总被已读不回?面试挂到怀疑人生?这几点你可能真没做好

最近看了几十份简历,发现大部分人不是技术差,而是不会“卖自己”——一、简历死穴:你写的不是经验,是岗位说明书!反面教材:ד使用SpringBoot开发项目”ד负责用户模块功能实现”救命写法:...

redission YYDS(redission官网)

每天分享一个架构知识Redission是一个基于Redis的分布式Java锁框架,它提供了各种锁实现,包括可重入锁、公平锁、读写锁等。使用Redission可以方便地实现分布式锁。red...

从数据库行锁到分布式事务:电商库存防超卖的九重劫难与破局之道

2023年6月18日我们维护的电商平台在零点刚过3秒就遭遇了严重事故。监控大屏显示某爆款手机SKU_IPHONE13_PRO_MAX在库存仅剩500台时,订单系统却产生了1200笔有效订单。事故复盘发...

SpringBoot系列——实战11:接口幂等性的形而上思...

欢迎关注、点赞、收藏。幂等性不仅是一种技术需求,更是数字文明对确定性追求的体现。在充满不确定性的网络世界中,它为我们建立起可依赖的存在秩序,这或许正是技术哲学最深刻的价值所在。幂等性的本质困境在支付系...

如何优化系统架构设计缓解流量压力提升并发性能?Java实战分享

如何优化系统架构设计缓解流量压力提升并发性能?Java实战分享在高流量场景下。首先,我需要回忆一下常见的优化策略,比如负载均衡、缓存、数据库优化、微服务拆分这些。不过,可能还需要考虑用户的具体情况,比...

Java面试题: 项目开发中的有哪些成长?该如何回答

在Java面试中,当被问到“项目中的成长点”时,面试官不仅想了解你的技术能力,更希望看到你的问题解决能力、学习迭代意识以及对项目的深度思考。以下是回答的策略和示例,帮助你清晰、有说服力地展示成长点:一...

互联网大厂后端必看!Spring Boot 如何实现高并发抢券逻辑?

你有没有遇到过这样的情况?在电商大促时,系统上线了抢券活动,结果活动刚一开始,服务器就不堪重负,出现超卖、系统崩溃等问题。又或者用户疯狂点击抢券按钮,最后却被告知无券可抢,体验极差。作为互联网大厂的后...

每日一题 |10W QPS高并发限流方案设计(含真实代码)

面试场景还原面试官:“如果系统要承载10WQPS的高并发流量,你会如何设计限流方案?”你:“(稳住,我要从限流算法到分布式架构全盘分析)…”一、为什么需要限流?核心矛盾:系统资源(CPU/内存/数据...

Java面试题:服务雪崩如何解决?90%人栽了

服务雪崩是指微服务架构中,由于某个服务出现故障,导致故障在服务之间不断传递和扩散,最终造成整个系统崩溃的现象。以下是一些解决服务雪崩问题的常见方法:限流限制请求速率:通过限流算法(如令牌桶算法、漏桶算...

面试题官:高并发经验有吗,并发量多少,如何回复?

一、有实际高并发经验(建议结构)直接量化"在XX项目中,系统日活用户约XX万,核心接口峰值QPS达到XX,TPS处理能力为XX/秒。通过压力测试验证过XX并发线程下的稳定性。"技术方案...

瞬时流量高并发“保命指南”:这样做系统稳如泰山,老板跪求加薪

“系统崩了,用户骂了,年终奖飞了!”——这是多少程序员在瞬时大流量下的真实噩梦?双11秒杀、春运抢票、直播带货……每秒百万请求的冲击,你的代码扛得住吗?2025年了,为什么你的系统一遇高并发就“躺平”...

其实很多Java工程师不是能力不够,是没找到展示自己的正确姿势。

其实很多Java工程师不是能力不够,是没找到展示自己的正确姿势。比如上周有个小伙伴找我,五年经验但简历全是'参与系统设计''优化接口性能'这种空话。我就问他:你做的秒杀...

PHP技能评测(php等级考试)

公司出了一些自我评测的PHP题目,现将题目和答案记录于此,以方便记忆。1.魔术函数有哪些,分别在什么时候调用?__construct(),类的构造函数__destruct(),类的析构函数__cal...

你的简历在HR眼里是青铜还是王者?

你的简历在HR眼里是青铜还是王者?兄弟,简历投了100份没反应?面试总在第三轮被刷?别急着怀疑人生,你可能只是踩了这些"隐形求职雷"。帮3630+程序员改简历+面试指导和处理空窗期时间...

取消回复欢迎 发表评论: