小天才Java架构方向面经(2)

他说雪花算法也有可能重复,怎么办?
(我说就正常的redis存储id去拿id,或者mysql自增id的方式也都可以)
他说那你讲讲你自己如何用mysql存储自增id?
(我说简单的方式我们就不说了,面试造火箭(我原话),因为直接mysql的自增id有一些缺点,可以考虑两张表,一张存储id,一张存储下一个获取id的范围,设计好索引,然后两张表一起查获取对应的ID,并且在合理的时间在执行对无用id数据的删除)
 现在有一个mysql,包含user和department表,这个department表中包含了多个子部门,也就是子部门的数量是不确定的,请设计一个表结构,帮助我查询出来某个部门所存在的所有用户
(这里我说由于自部门数量不确定,所以我考虑用string或者bitmap类型存储自部门的编号,然后设定一个parentid,自部门编号类似于{1,2,3}这样子,然后partent=0或者null。
然后查询就很简答了啊,userid=3-0-》deparetmenid=0.
然后查询出来0的自部门id字段也就是ids字段「1,2,3」,然后直接查询所有用户depaetmentid=1,2,3范围的用户就可以了。)
他说ok,可以,那么我现在希望呢只是用一条查询sql来帮助我查询某个部门下面的所有用户,同时如果我要修改你这个parentid,你也只能用一条update语句去修改,你怎么做?
(其实这个时候我刚才设计的结构就不合理了,因为一条根本做不到,我说可以考虑额外增加一个字段,这个字段存储其他部门的一些信息,但是由于这个字段要存储其他部门的信息,而且你还需要解析,因为是字符串你肯定得解析,然后我就说我想不出来,因为性能太差了(毕竟是架构面,所以我觉得解决问题甚至不是最重要的,甚至性能才是被我考虑的,这种低性能的解决方式我就直接不回答了))。
你说的额外字段你要怎么设计?
(我说用这个字段存储其他部门的全量路径信息,但是性能爆炸,所以我想不出来更好的了,因为我知道要在一条sql里面就完成update,那肯定得有额外字段了)

解决方法看我主页。
全部评论
我一面问的这些问题
点赞 回复 分享
发布于 2024-09-25 21:57 日本
好强
点赞 回复 分享
发布于 2023-11-08 22:53 北京

相关推荐

个人背景:学院二本计科专业 大二开始实习个人经历:安克创新 、理想汽车、字节跳动碎碎念:我做事只有三分钟热度。看到进了大厂的同学,我会羡慕,也会跟着努力上进;但遇到好看的小说,我又会放下手头的事沉迷其中,之前的坚持也就中断了。我有些自卑,总觉得自己学历和外貌都不够好。之前偶然在网上受到关注,我就喜欢上了上网,因为这里有很多人认可我。但我也很在意别人的评价,偶尔看到嘲讽的言论,会触发我的自卑情绪,让我感到愤怒。有时候我会强硬地回怼,有时候又会懦弱地选择无视。我也有虚荣心。不管是拿到安克、理想还是字节的机会,我在分享的时候都会带着这份心思。我会特意强调自己学历不好,是为了衬托出过程的艰难,以此显得自己更厉害。我知道,人往往会炫耀自己缺少的东西,来掩盖内心的空洞。我总想着走捷径,不太喜欢踏踏实实地做事。找实习的时候,我花了更多时间在研究面试技巧上,而不是提升专业能力。我会反复听面试录音分析技巧,看面试教程学习怎么和不同的面试官沟通,还会每天自言自语练习语言表达,同学都觉得我有点奇怪。我的实习生涯里,侥幸和运气占了很大一部分。我总在想,如果有一天我失去了这份幸运,这些特质可能会让我一蹶不振。ps: 很多人会问我学习路线和经验 但是就像我上面说的 我的实习过程靠的很多是关键节点的运气 技术上面我可能不如很多人  所以请大家理性求助和理性参考我的回答 附上我的投递记录
我的offer在哪里...:从去年看到现在,飞升哥就是榜样
我的求职进度条
点赞 评论 收藏
分享
评论
3
13
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务