最近面试中遇到的问题小总结——JAVA开发


1.mysql语法有则新增 无则修改
    a.唯一索引
    b.insert into 表名(字段1,userId,字段3,....) values(值1,值,值3,....) on duplicate key update 字段1=值1,字段2=值2 ....
2.数据库索引类型
    1、普通索引:最基本的索引,没有任何约束。
    2、唯一索引:与普通索引类似,但具有唯一性约束。
    3、主键索引:特殊的唯一索引,不允许有空值。
    4、复合索引:将多个列组合在一起创建索引,可以覆盖多个列。
    5、外键索引:只有InnoDB类型的表才可以使用外键索引,保证数据的一致性、完整性和实现级联操作。
    6、全文索引:MySQL 自带的全文索引只能用于 InnoDB、MyISAM ,并且只能对英文进行全文检索,一般使用全文索引引擎。
3.如何判断索引失效
    索引失效分析工具:可以使用explain命令加在要分析的sql语句前面,在执行结果中查看key这一列的值,如果为NULL,说明没有使用索引。explain命令的详细用法,可以查看这篇文章:https://segmentfault.com/a/1190000008131735
    1、like 以%开头,索引无效;当like前缀没有%,后缀有%时,索引有效。
    2、or语句前后没有同时使用索引。当or左右查询字段只有一个是索引,该索引失效,只有当or左右查询字段均为索引时,才会生效
    3、组合索引,不是使用第一列索引,索引失效。
    4、数据类型出现隐式转化。如varchar不加单引号的话可能会自动转换为int型,使索引无效,产生全表扫描。
    5、在索引列上使用 IS NULL 或 IS NOT NULL操作。索引是不索引空值的,所以这样的操作不能使用索引,可以用其他的办法处理,例如:数字类型,判断大于0,字符串类型设置一个默认值,判断是否等于默认值即可。
    6、在索引字段上使用not,<>,!=。不等于操作符是永远不会用到索引的,因此对它的处理只会产生全表扫描。 优化方法: key<>0 改为 key>0 or key<0。
    7、对索引字段进行计算操作、字段上使用函数。(索引为 emp(ename,empno,sal))
    8、当全表扫描速度比索引速度快时,mysql会使用全表扫描,此时索引失效。
4.复合索引
5.mybatis和mybatis plus区别
6.前后端怎么交互
    ① 发送请求
    ② 映射处理器
    ③ 处理器适配
    ⑤ 解析视图
    ⑥ ⑦ 渲染视图 + 响应请求
    但是 HTTP 是不支持返回 Java POJO 对象的,所以需要将结果使用 HttpMessageConverter 进行转换后,才能返回。例如说,大家所熟悉的 FastJsonHttpMessageConverter ,将 POJO 转换成 JSON 字符串返回。
7.RestTemplate 的优势是什么?
在 Spring Framework 中,RestTemplate 类是 模板方法模式 的实现。跟其他主流的模板类相似,如 JdbcTemplate 或 JmsTempalte ,它将在客户端简化跟 RESTful Web 服务的集成。正如在 RestTemplate 例子中显示的一样,你能非常容易地用它来调用 RESTful Web 服务。
8.springmvc
    同6
9.@SpringBootApplication
    就是 Spring Boot 的核心注解。
    组合了三个注解
    @Configuration 注解,指定类是 Bean 定义的配置类。
    #ComponentScan 注解,扫描指定包下的 Bean 们。
    @EnableAutoConfiguration 注解,打开自动配置的功能。如果我们想要关闭某个类的自动配置,可以设置注解的 exclude 或 excludeName 属性。
    https://blog.csdn.net/claram/article/details/75125749
10.解释下单例模式 工厂模式
11.MySQL 有哪些存储引擎?
    InnoDB
    MyISAM
    MRG_MYISAM
    MEMORY
    CSV
    ARCHIVE
    BLACKHOLE
    PERFORMANCE_SCHEMA
    FEDERATED
    是否需要支持事务。
    对索引和缓存的支持。
    是否需要使用热备。
    崩溃恢复,能否接受崩溃。
    存储的限制。
    是否需要外键支持。
    目前,MySQL 默认的存储引擎是 InnoDB ,并且也是最主流的选择。主要原因如下:

    【最重要】支持事务。
    支持行级锁和表级锁,能支持更多的并发量。
    查询不加锁,完全不影响查询。
    支持崩溃后恢复。
12.mysql锁
    共享锁:不堵塞,多个用户可以同时读一个资源,互不干扰。
    排他锁:一个写锁会阻塞其他的读锁和写锁,这样可以只允许一个用户进行写入,防止其他用户读取正在写入的资源。
     锁的粒度?

    表锁:系统开销最小,会锁定整张表,MyIsam 使用表锁。
    行锁:最大程度的支持并发处理,但是也带来了最大的锁开销,InnoDB 使用行锁。
    1)悲观锁
    2)乐观锁
     什么是死锁?
 13.MySQL 的四种事务隔离级别?
     acid
     原子性 Atomicity :一个事务(transaction)中的所有操作,或者全部完成,或者全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被恢复(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。即,事务不可分割、不可约简。
    一致性 Consistency :在事务开始之前和事务结束以后,数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设约束、触发器)、级联回滚等。
    隔离性 Isolation :数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离分为不同级别,包括读未提交(Read uncommitted)、读提交(read committed)、可重复读(repeatable read)和串行化(Serializable)。
    持久性 Durability :事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失


 

你可能感兴趣的:(java)