博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
忻知电面面筋狗
阅读量:3808 次
发布时间:2019-05-22

本文共 2489 字,大约阅读时间需要 8 分钟。

忻知电面面筋狗

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

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的命令操作,所以重新了解一下:
  • 不过个人觉得再多的博客还不如看官方文档:
  • 截图为证:

  • 以上就是我在这次电话面试中的收获,记录一下下,充实下自己。如有不足和错误,还望大佬更正。
  • 大家有兴趣可以访问我的博客

转载地址:http://loaxn.baihongyu.com/

你可能感兴趣的文章
GC收集器
查看>>
静态分派和动态分派
查看>>
ICMP
查看>>
Scroller类
查看>>
Java并发知识——Concurrent包
查看>>
TCP粘包
查看>>
Android 自定义控件 轻松实现360软件详情页
查看>>
程序员的自我修养——操作系统篇
查看>>
关于多态的一道题
查看>>
foreach
查看>>
怎么保证service不被杀死
查看>>
Android HandlerThread 完全解析
查看>>
Android布局
查看>>
Android中弱引用与软引用的应用场
查看>>
Android框架
查看>>
Dalvik虚拟机垃圾收集机制
查看>>
Android应用程序在新的进程中启动新的Activity的方法和过程分析
查看>>
Android应用程序的Activity启动过程简要介绍和学习计划
查看>>
Message的参数和方法
查看>>
View的顶点坐标以及getMeasuredWidth和getWidth
查看>>