忻知电面面筋狗

忻知电面面筋狗

  • 一直想经历一次电话面试,于是乎电面来了,和和蔼的面试小哥哥聊了一会天,发现自己的一些不足,特此记录一下。

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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值