前言
闲来无事,收到阿里APP推送,于是就花9.9买了,学习手册其实之前就有看过,平时开发大部分也是按照手册执行的。
今天花了一天的时间重新系统性的复习了下《java开发手册-华山版》,晚上用了四十分钟结束了战斗。
学习资料
部分试题
33.【强制】不得使用外键与级联,一切外键概念必须在应用层解决。
说明:以学生和成绩的关系为例,学生表中的 student_id是主键,那么成绩表中的 student_id则为外键。如果更新学生表中的 student_id,同时触发成绩表中的 student_id 更新,即为级联更新。外键与级联更新适用于单机低并发,不适合分布式、高并发集群;级联更新是强阻塞,存在数据库更新风暴的风险;外键影响数据库的插入速度。
34.【强制】count(distinct col) 计算该列除 NULL 之外的不重复行数,注意 count(distinct col1, col2) 如果其中一列全为 NULL,那么即使另一列有不同的值,也返回为 0。
35.mysql使用sum函数注意判空操作
【强制】当某一列的值全是 NULL 时,count(col)的返回结果为 0,但 sum(col)的返回结果为NULL,因此使用 sum()时需注意 NPE 问题。
正例:可以使用如下方式来避免 sum 的 NPE 问题:SELECT IF(ISNULL(SUM(g)),0,SUM(g)) FROM table;
sum(null)=====>null
count(null)=====>0
36.KV结构的集合,在处理null值的存储上有细微的区别,下列哪些说法是正确的:A
A .TreeMap的key不可以为null
B .TreeMap的key可以为null
C .ConcurrentHashMap的key可以为null
D .ConcurrentHashMap的value可以为null
注释:HashMap的key/value均可以为null,但是TreeMap的key不能为空,value可以为空
37.数组使用Arrays.asList转化为集合,下列说法哪些正确的:ACD
A .数组元素的修改,会影响到转化过来的集合。
B .数组元素的修改,不会影响到转化过来的集合。
C .对于转换过来的集合,它的 add/remove/clear 方法会抛出: UnsupportedOperationException。
D .A