伴随着今日头条、抖音、Tiktok等产品在生活中普及,字节跳动越发进入程序员群体的求职视野。舒适的工作环境、完善的福利待遇、薪资、上升空间……这些条件吸纳了无数新鲜血液涌向字节跳动。
那,如何才能成功入职呢?不妨先做做真题试试深浅吧。
Question1.什么是 Mybatis?
Mybatis 是一个半 ORM(对象关系映射)框架,它内部封装了 JDBC,开发时只需要关注SQL语句本身,不需要花费精力去处理加载驱动、创建连接、创建 statement 等繁杂的过程。程序员直接编写原生态sql,可以严格控制sql执行性能,灵活度高。MyBatis可以使用XML或注解来配置和映射原生信息,将POJO映射成数据库 中的记录,避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。 通过xml文件或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射为 java 对象并返回。
Question2.Mybaits 的优点
基于SQL语句编程,相当灵活,不会对应用程序或者数据库的现有设计造成任何影响。SQL写在XML里,解除sql与程序代码的耦合,便于统一管理;提供XML标签,支持编写动态SQL语句,并可重用。与JDBC相比,减少了50%以上的代码量,消除了JDBC大量冗余的代码,不需要手动开关连接;很好的与各种数据库兼容(因为MyBatis使用JDBC来连接数据库,所以只要JDBC支持的数据库MyBatis都支持)。能够与Spring很好的集成;提供映射标签,支持对象与数据库的ORM字段关系映射;提供对象关系映射标签,支持对象关系组件维护。
Question3.MyBatis 框架的缺点
SQL语句的编写工作量较大,尤其当字段多、关联表多时,对开发人员编写SQL语句的功底有一定要求。SQL语句依赖于数据库,导致数据库移植性差,不能随意更换数据库。
Question4.MyBatis 框架适用场合
MyBatis专注于SQL本身,是一个足够灵活的DAO层解决方案。对性能的要求很高,或者需求变化较多的项目,如互联网项目,MyBatis将是不错的选择。
Question5.#{}和${}的区别是什么
#{}是预编译处理,${}是字符串替换。Mybatis在处理#{}时,会将sql中的#{}替换为?号。调用PreparedStatement的set方法来赋值;Mybatis在处理${}时,就是把${}替换成变量的值。使用#{}可以有效的防止SQL注入,提高系统安全性。
Question6.如何执行批量插入
首先,创建一个简单的 insert 语句:
然后在 java 代码中像下面这样执行批处理插入:
Question7.Mybatis 动态 sql 有什么用?执行原理?有哪些动态 sql?
Mybatis动态sql可以在Xml映射文件内,以标签的形式编写动态sql,执行原理是根据表达式的值完成逻辑判断并动态拼接sql的功能。Mybatis提供了9种动态sql标签:trim、where、set、foreach、if、choose、when、otherwise、bind。
Question8.Mybatis的Xml映射文件中,不同的Xml映射文件,id是否可以重复?
不同的Xml映射文件,如果配置了namespace,那么id可以重复;如果没有配置namespace,那么id不能重复。原因就是namespace+id是作为Map<String,MapperStatement>的key使用的,如果没有namespace,就剩下id,那么,id重复会导致数据互相覆盖。有了namespace,自然id就可以重复,namespace不同,namespace+id自然也就不同。
Question9.为什么说Mybatis是半自动ORM映射工具?它与全自动的区别在哪里?
Hibernate属于全自动ORM映射工具。使用Hibernate查询关联对象或者关联集合对象时,可以根据对象关系模型直接获取,所以它是全自动的。而Mybatis在查询关联对象或关联集合对象时,需要手动编写sql来完成,所以,称之为半自动ORM映射工具。
Question10.MyBatis实现一对一有几种方式?具体怎么操作的?
有联合查询和嵌套查询。联合查询是几个表联合查询,只查询一次,通过在resultMap里面配置association节点配置一对一的类就可以完成。嵌套查询是先查一个表,根据这个表里面的结果的外键id,去另外一个表里面查询数据,也是通过association配置,但另外一个表的查询通过select属性配置。
Question11.MyBatis实现一对多有几种方式,怎么操作的?
有联合查询和嵌套查询。联合查询是几个表联合查询,只查询一次,通过在resultMap里面的collection节点配置一对多的类就可以完成。嵌套查询是先查一个表,根据这个表里面的结果的外键id,去另外一个表里面查询数据,也是通过配置collection,但另外一个表的查询通过select节点配置。
对想加入字节跳动的求职者而言,结合出题点做好笔试准备,无疑是提高了拿到offer的概率。