忻知电面面筋狗
- 一直想经历一次电话面试,于是乎电面来了,和和蔼的面试小哥哥聊了一会天,发现自己的一些不足,特此记录一下。
mysql连接
基本概念
连接(join)就是将多个表中的字段根据匹配条件进行横向的拼接。
- 左表:在语法上位于join左边的表,叫左表。
- 右表:在语法上位于join右边的表,叫右表。
交差连接(cross join)
左表中的每一行数据去匹配右表中的每一行数据,且认为全部匹配成功。最终的结果集是迪卡尔积。
语法:
select * from 左表 cross join 右表;
示例:
说明:此类连接不常用。
内连接(inner join)
使用左表中的每一条记录去匹配右表的所有的记录,根据匹配的条件,如果成立,保留整条记录,如果不成立则丢弃。
用文氏图表示,则如下:
语法:
select * from 左表 【inner】 join 右表 【on 条件】
示例:
左连接(left join)
将左表作为主表,用主表中的每一条记录,去匹配从表(右表)中的所有记录,根据匹配的条件,如果成功则将主表的记录中的字段与从表的记录中的记录,拼接成一条完整的记录,放到结果集;如果不成功则将从表中的记录中的字段全部置为null,保留主表中的字段。
用文氏图表示,如下:
语法:
select * from 左表 left join 右表【on条件】
示例:
右连接(right join)
将右表作为主表,用主表中的每一条记录,匹配从表中的所有记录,根据匹配的条件,如果成功则将主表的记录中的字段与从表的记录中的记录,拼接成一条完整的记录,放到结果集。如果不成功则将从表中的记录中的字段全部置为null,保留主表中的字段。
用文氏图表示,如下.
语法:
select * from 左表 right join 右表【on条件】
示例:
自然连接(natural join)
对两表进行连接查询时,系统会盲目的用同名字段为匹配条件。会合并同名字段,并且将匹配字段放到结果集的前面。
自然连接分为左自连接和右自然连接。
- 直接使用natural join连接主表和从表,相当于内连接.
- 当使用natural left join时,相当于左连接.
- 当使用natural right join时,相当于右连接.
自然链接(natural join)
语法:
select * from 左表 natural join 右表.
示例:
左自然连接(natural left join)
语法:
select * from 左表 natural left join 右表.
示例:
右自然连接(natural right join)
语法:
select * from 左表 natural right join 右表.
示例:
懒汉模式
- 之前有详细介绍过单例模式,但当面试小哥哥问到饿汉模式懒汉模式还是有点没反应过来,其实在之前那篇博客中的最初写法和线程安全写法就是了
- 但为了加强记忆还是再写一遍吧
饿汉式单例模式
饿汉式单例模式示意图:
.
饿汉式单例模式:HurrySingleton.java.
package com.wewin.power_manage.controller;
/**
* @Author: William
* @Description:
* @Date: 2018/11/6 11:18
**/
public class HurrySingleton {
private static final HurrySingleton INSTANCE = new HurrySingleton();
//私有化构造子,阻止外部直接实例化对象
private HurrySingleton() {
}
/**
* 返回类的唯一实例
* @return instance
*/
public static HurrySingleton getInstance() {
return INSTANCE;
}
}
懒汉式单例模式
懒汉式单例模式示意图:
.
懒汉式单例模式:LazySignleton.java.
package com.wewin.power_manage.controller;
/**
* @Author: William
* @Description:
* @Date: 2018/11/6 11:30
**/
public class LazySingleton {
private static LazySingleton INSTANCE = null;
//私有化构造子,阻止外部直接实例化对象
private LazySingleton() {
}
/**
*
* 获取类的单例实例
* @return instance
*/
public static LazySingleton getInstance() {
if (INSTANCE == null) {
synchronized (LazySingleton.class) {
if (INSTANCE == null) {
INSTANCE = new LazySingleton();
}
}
}
return INSTANCE;
}
}
redis命令
- 之前在做session共享过程用到过redis,但是没有详细讲解redis的命令操作,所以重新了解一下:
- 不过个人觉得再多的博客还不如看官方文档:redis命令参考
- 截图为证:
- 以上就是我在这次电话面试中的收获,记录一下下,充实下自己。如有不足和错误,还望大佬更正。
- 大家有兴趣可以访问我的博客 DreamWord