第一次面试面试题

第一次面试面试题

  1. 项目中负责开发的功能。

    答:设施设备综合管理平台的报修模块,巡检模块,库存模块,台账模块。

    这块我觉得应该说的跟贴近于技术,而不是业务。

  2. 如何使用的activiti

    答:简单使用。

    我觉得应该去看一下activiti的简单面试题,不然感觉会让面试官觉得只是浅浅的会用,不去了解底层。

  3. mybatis #{} 和 ${}的区别

    答:#{}是预编译处理,${}是字符串替换;使用#{}可以有效的防止SQL注入,提高系统安全性。

    理想答案:

    • #{}是预编译处理,${}是字符串替换;
    • Mybatis在处理#{}时,会将sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值;
    • Mybatis在处理 时 , 就 是 把 {}时,就是把 {}替换成变量的值;
    • 使用#{}可以有效的防止SQL注入,提高系统安全性。
  4. mybatis 常用sql 动态标签

    答:不太知道什么是sql 动态标签。
    理想答案:

    动态sql的9个标签,trim|where|set|foreach|if|choose|when|otherwise|bind

    1、if

    if 标签通常用于 WHERE 语句、UPDATE 语句、INSERT 语句中,通过判断参数值来决定是否使用某个查询条件、判断是否更新某一个字段、判断是否插入某个字段的值。

    <if test="name != null and name != ''">
        and NAME = #{name}
    </if>
    

    2、foreach

    foreach 标签主要用于构建 in 条件,可在 sql 中对集合进行迭代。也常用到批量删除、添加等操作中。

    <!-- in查询所有,不分页 -->
    <select id="selectIn" resultMap="BaseResultMap">
        select name,hobby from student where id in
        <foreach item="item" index="index" collection="list" open="(" separator="," close=")">
            #{item}
        </foreach>
    </select>
    
    • collection:collection 属性的值有三个分别是 list、array、map 三种,分别对应的参数类型为:List、数组、map 集合。
    • item :表示在迭代过程中每一个元素的别名
    • index :表示在迭代过程中每次迭代到的位置(下标)
    • open :前缀
    • close :后缀
    • separator :分隔符,表示迭代时每个元素之间以什么分隔

    3、choose when otherwise

    有时候我们并不想应用所有的条件,而只是想从多个选项中选择一个。MyBatis 提供了 choose 元素,按顺序判断 when 中的条件出否成立,如果有一个成立,则 choose 结束。当 choose 中所有 when
    的条件都不满则时,则执行 otherwise 中的 sql。类似于 Java 的 switch 语句,choose 为 switch,when 为 case,otherwise 则为 default。

    if 是与(and)的关系,而 choose 是或(or)的关系。

    <select id="getStudentListChoose" parameterType="Student" resultMap="BaseResultMap">
        SELECT * from STUDENT WHERE 1=1
        <where>
            <choose>
                <when test="Name!=null and student!='' ">
                    AND name LIKE CONCAT(CONCAT('%', #{student}),'%')
                </when>
                <when test="hobby!= null and hobby!= '' ">
                    AND hobby = #{hobby}
                </when>
                <otherwise>
                    AND AGE = 15
                </otherwise>
            </choose>
        </where>
    </select>
    

    4、where

    当 name 值为 null 时,查询语句会出现 “WHERE AND” 的情况,解决该情况除了将"WHERE"改为“WHERE 1=1”之外,还可以利用 where
    标签。这个“where”标签会知道如果它包含的标签中有返回值的话,它就插入一个‘where’。此外,如果标签返回的内容是以 AND 或 OR 开头的,则它会剔除掉。

    <select id="getStudentListWhere" parameterType="Object" resultMap="BaseResultMap">
        SELECT * from STUDENT
        <where>
            <if test="name!=null and name!='' ">
                NAME LIKE CONCAT(CONCAT('%', #{name}),'%')
            </if>
            <if test="hobby!= null and hobby!= '' ">
                AND hobby = #{hobby}
            </if>
        </where>
    </select>
    

    5、set

    没有使用 if 标签时,如果有一个参数为 null,都会导致错误。当在 update 语句中使用 if 标签时,如果最后的 if 没有执行,则或导致逗号多余错误。使用 set 标签可以将动态的配置 set
    关键字,和剔除追加到条件末尾的任何不相关的逗号。

    使用 set+if 标签修改后,如果某项为 null 则不进行更新,而是保持数据库原值。

    <update id="updateStudent" parameterType="Object">
        UPDATE STUDENT SET
        <if test="name!=null and name!='' ">
            NAME = #{name},
        </if>
        <if test="hobby!=null and hobby!='' ">
            MAJOR = #{major},
        </if>
        <if test="hobby!=null and hobby!='' ">
            HOBBY = #{hobby}
        </if>
        WHERE ID = #{id};
    </update>
    
    <update id="updateStudent" parameterType="Object">
        UPDATE STUDENT
        <set>
            <if test="name!=null and name!='' ">
                NAME = #{name},
            </if>
            <if test="hobby!=null and hobby!='' ">
                MAJOR = #{major},
            </if>
            <if test="hobby!=null and hobby!='' ">
                HOBBY = #{hobby}
            </if>
        </set>
        WHERE ID = #{id};
    </update>
    

    6、trim

    trim标记是一个格式化的标记,主要用于拼接sql的条件语句(前缀或后缀的添加或忽略),可以完成set或者是where标记的功能。

    trim属性主要有以下四个

    • prefix:在trim标签内sql语句加上前缀
    • suffix:在trim标签内sql语句加上后缀
    • prefixOverrides:指定去除多余的前缀内容,如:prefixOverrides=“AND | OR”,去除trim标签内sql语句多余的前缀"and"或者"or"。
    • suffixOverrides:指定去除多余的后缀内容。
    <update id="updateByPrimaryKey" parameterType="Object">
    	update student set 
    	<trim  suffixOverrides=",">
    		<if test="name != null">
    		    NAME=#{name},
    		</if>
    		<if test="hobby != null">
    		    HOBBY=#{hobby},
    		</if>
    	</trim> 
    	where id=#{id}
    </update>
    
    <select id="selectByNameOrHobby" resultMap="BaseResultMap">
    	select * from student 
    	<trim prefix="WHERE" prefixOverrides="AND | OR">
    		<if test="name != null and name.length()>0"> 
    			AND name=#{name}
    		</if>
    		<if test="hobby != null and hobby.length()>0">
    			AND hobby=#{hobby}
    		</if>
    	</trim>
    </select>
    

    7、bind

    bind 标签是通过 OGNL 表达式去定义一个上下文的变量, 这样方便我们使用。在 MySQL 中, 该函数支持多参数, 但在 Oracle 中只支持两个参数。那么我们可以使用 bind 来让该 SQL 达到支持两个数据库的作用。

    <if test="name != null and name !=''">
         <bind name="nameLike" value="'%'+name+'%'"/>
         and name like #{nameLike}
    </if>
    
  5. 有没有用过redis有没有配置经验

    答:没有。只是自己学的时候有过配置。

    应该直接回答有的,不然redis直接不问了。

  6. spring boot 核心注解 哪几个注解组成的

    答:少说了一个,就不在问了。

    理想答案:

    启动类上面的注解是@SpringBootApplication,它也是 Spring Boot 的核心注解,主要组合包含了以下 3 个注解:

    @SpringBootConfiguration:组合了 @Configuration 注解,实现配置文件的功能。

    @EnableAutoConfiguration:打开自动配置的功能,也可以关闭某个自动配置的选项,如关闭数据源自动配置功能: @SpringBootApplication(exclude = { DataSourceAutoConfiguration.class })。

    @ComponentScan:Spring组件扫描。

    ε=(´ο`*)))唉,感觉说的结结巴巴的,下次看面试题的时候一定读出来,不然知道却说不出来干着急。

  7. 微服务里面如何实现session的共享

    答:没用过

    理想答案:网上查的spring session + redis

    集群部署时的分布式 session 如何实现?

    一线大厂常考面试题:分布式Session共享解决方案

  8. 数据库 mysql查询优化

    答:记不清楚怎么答的了,就说了加索引

    理想答案:

    主要是从怎么合理创建索引 合理编写 SQL 语句和防止索引失效 合理创建表字段这3个方面入手

    • 合理创建索引:

    • 合理编写 SQL 语句:

      不使用 select *,使用 LIMIT 语句来限制返回的数据,IN包含的值不应过多等

    • **防止索引失效:**保证最左前缀法则,尽量不适用前缀模糊查询 %like,避免索引列参与计算或使用了函数,避免在where子句中对字段进行null值判断,看看表编码,表字段是否一样,联合索引中范围查询会让后面的索引字段失效,join查询时要用小表驱动大表

    • 合理创建表字段: 最好不要给数据库留NULL,尽可能的使用 NOT NULL填充数据库

  9. mysql 是否支持事务处理

    答:支持事务。

    理想答案:

    5.6版本之前,mysql的默认引擎是Myisam不支持事务。
    5.6版本之后,默认引擎是InnoDB支持事务,有四种隔离级别,未提交读、已提交读、可重复读、串行化,默认可重复读。

  10. mysql 的索引是针对性的构建 还是全加

    答:选择性加。

    我觉得面试官应该是问我最佳左前缀法则

    理想答案:

    最佳左前缀法则:

    指的是查询从索引的最左前列开始并且不跳过索引中的列。 在创建索引的字段中第一个就是最左,每个左边的字段都是后面一个字段的一整个树,过滤条件要使用索引必须按照索引建立时的顺序,依次满足,一旦跳过某个字段,索引后面的字段都无法被使用。要按照顺序命中索引

  11. mysql的调优

    答:不会。。。

    理想答案:

    使用了索引却仍然不是很快,就使用 explain 分析了一下发现表中有多个索引,因为可能涉及回表,排序的操作,MySQL 优化器选用了错误的索引导致查询效率偏低,然后通过 SQL 语句中使用 useindex 来指定索引解决。

  12. redis除了缓存还能做什么

    答:消息队列

    理想答案:

    1. 缓存
    2. 共享Session
    3. 消息队列系统
    4. 分布式锁
  13. redis 支持几种数据类型

    答:8种,然后问最后3种就说了Geospatial。

    理想答案:

    字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) 与, bitmaps, hyperloglogs 和 地理空间(geospatial) 索引半径查询。

  14. 数据库如何设计

    答:就说满足业务。。。

    理想答案:

    首先划分为两大部分,一个存储部分,类似文件系统将数据持久化到硬盘上, 另一个是程序实例部分,创建模块: 存储管理,缓存机制,SQL解析,日志管理,权限划分,容灾机制**,索引管理,锁模块**。

  15. Linux系统

    答:不太会。

  16. 中间件

    答:没用过。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值