Mybatis-基础

  • Mybatis简介
  1. 基于java的持久层框架,内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程
  2. 通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射为java对象并返回
  3. 支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集
  • Mybatis优点
  1. 简单易学,容易上手,基于SQL编程;
  2. JDBC相比,减少了50%以上的代码量,消除了JDBC大量冗余的代码,不需要手动开关连接;
  3. 很好的与各种数据库兼容(因为MyBatis使用JDBC来连接数据库,所以只要JDBC支持的数据库MyBatis都支持,而JDBC提供了可扩展性,所以只要这个数据库有针对Java的jar包就可以就可以与MyBatis兼容),开发人员不需要考虑数据库的差异性。
  4. 提供了很多第三方插件(分页插件 / 逆向工程);
  5. 灵活,不会对应用程序或者数据库的现有设计强加任何影响,SQL写在XML里,从程序代码中彻底分离,解除sql与程序代码的耦合,便于统一管理和优化,并可重用。
  6. 提供XML标签,支持编写动态SQL语句。
  7. 提供映射标签,支持对象与数据库的ORM字段关系映射。
  8. 提供对象关系映射标签,支持对象关系组建维护。
  • Mybatis缺点

  1. SQL语句的编写工作量较大,尤其是字段多、关联表多时,更是如此,对开发人员编写SQL语句的功底有一定要求。
  2. SQL语句依赖于数据库,导致数据库移植性差,不能随意更换数据库。
  • Mybatis适用场合
  1. MyBatis专注于SQL本身,是一个足够灵活的DAO层解决方案。
  2. 对性能的要求很高,或者需求变化较多的项目,如互联网项目,MyBatis将是不错的选择。

其他

  • MyBatis在核心处理类叫什么
  1.     MyBatis里面的核心处理类叫做SqlSession
  • MyBatis的接口绑定,有什么好处?
  1. 接口映射就是在IBatis中任意定义接口,然后把接口里面的方法和SQL语句绑定,我们直接调用接口方法就可以了
  2. 这样比起原来了SqlSession提供的方法我们可以有更加灵活的选择和设置.
  • MyBatis注解绑定、xml绑定
  1. 当Sql语句比较简单时候,用注解绑定,
  2. 当SQL语句比较复杂时候,用xml绑定,一般用xml绑定的比较多
  • MyBatis的缓存
  1. MyBatis的缓存分为一级缓存和二级缓存,一级缓存放在session里面,默认就有,
  2. 二级缓存放在它的命名空间里,默认是打开的,使用二级缓存属性类需要实现Serializable序列化接口(可用来保存对象的状态),可在它的映射文件中配置<cache/> 

 

  • MyBatis中使用#和$书写占位符
  1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号
  2. $将传入的数据直接显示生成在sql中
  3. #方式能够很大程度防止sql注入。
  4. $方式无法防止Sql注入。
  5. 一般能用#的就别用$.
  • MyBatis中命名空间(namespace)的作用
  1. 在大型项目中,可能存在大量的SQL语句,这时候为每个SQL语句起一个唯一的标识(ID)就变得并不容易了
  2. 为了解决这个问题,在MyBatis中,可以为每个映射文件起一个唯一的命名空间,这样定义在这个映射文件中的每个SQL语句就成了定义在这个命名空间中的一个ID。
  3. 只要我们能够保证每个命名空间中这个ID是唯一的,即使在不同映射文件中的语句ID相同,也不会再产生冲突了。

参考:

  1. 常见面试题之框架篇MyBatis
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值