mybatis入门

Java的三大框架:Spring,SpringMVC,MyBatis

框架其实就是对通用代码的封装,提前写好了一堆接口和类,我们可以在做项目的时候直接引入这些接口和类,基于这些现有的接口和类进行开发,可以大大提高开发效率

JDBC的不足

代码繁琐,复用性低

了解Mybatis

MyBatis本质上就是对JDBC的封装,通过MyBatis完成CRUD

MyBatis在三层架构中属于持久化层,属于持久化框架

ORM思想--对象关系映射

ORM对象关系的映射

  • O(Object):Java虚拟机中的Java对象
  • R(Relational):关系型数据库
  • M(Mapping):将Java虚拟机中的Java对象映射到数据库表中一行记录,或是将数据库表中的一行记录映射成Java虚拟机中的一个Java对象

映射:把数据库中的一条记录转换成一个Java对象或者一个Java对象转换成数据库表中的一条记录的过程叫做映射

MyBatis框架实现了ORM思想

MyBatis可以将Java对象<-->数据库中的一条记录

MyBatis是一个半自动化的ORM,因为MyBatis框架中的SQL语句需要手动编写,比较灵活

像User这种类有三种叫法:pojo(普通Java类),bean,domain

MyBatis的优点
  • 支持定制化SQL,存储过程,基本映射以及高级映射
  • 避免了几乎所有的JDBC代码中手动设置参数以及获取结果集
  • 支持XML开发,也支持注解式开发(为了保证sql语句的灵活性,mybatis大部分采用xml开发)
  • 将接口和Java的pojo映射成数据库中的记录
  • 完全做到sql解耦合
  • 提供了基本映射标签
  • 提供了高级映射标签

提供了xml标签,支持动态SQL的编写

MyBatis入门

resources目录:

放在这个目录当中的,一般都是资源文件,配置文件

直接放到resources目录下的资源,等同于放到了类的根路径下

开发步骤
  1. 打包方式jar
  2. 引入依赖:
    -mybatis依赖
    -mysql驱动依赖
  3. 编写mybatis核心配置文件
    文件名不一定叫做mybatis-config
    放的位置也不一定在resources目录下,但一定是在根目录下的
  4. 编写XXXMapping.xml文件编写sql语句
  5. 在mybatis-config文件的mapper标签中指定编写sql语句的文件路径,resource会默认从类的根路径下查找文件
  6. 编写mybatis程序

从xml文件中构建sqlSessionFactory

mybatis有两个重要的配置文件:

  • mybatis-config.xml,这是核心配置文件,用来配置连接数据库的信息等
  • XxxxMapping.xml,这个文件是专门用来编写sql语句的文件

在Mapping.xml文件中编写sql语句时,id是sql语句的唯一标识,id代表了这条sql语句

编写mybatis程序

SqlSession是专门用来执行sql语句的,是一个Java程序和数据库之间得到一个会话

要想 获取SqlSession对象就要先获取SqlSessionFactory对象

要想 获取SqlSessionFactory对象就要先获取SqlSessionFactoryBuilder对象

通过 SqlSessionFactoryBuilder的build方法来获取SqlSessionFactory对象

SqlSessionFactoryBuilder->SqlSessionFactory->SqlSession

复制代码
 public static void main(String[] args) throws IOException {
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
        //需要传入一个输入流指向mybatis-config.xml
        InputStream ips = Resources.getResourceAsStream("mybatis-config.xml");//Resources.getResourceAsStream默认从根路径下开始查找资源
        SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(ips);
        //通过sqlSessionFactory的openSession方法获取sqlSession对象
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //返回值是影响数据库中的记录条数
     	int insertCar = sqlSession.insert("insertCar");
        System.out.println(insertCar);
        //sqlSession默认的是不自动提交,需要手动提交
        sqlSession.commit();
    }

一般情况下都是一个数据库对应一个SqlSessionFactory

mybatis中sql语句的结尾 分号 可以省略也可以不省略

以后凡是遇到resource的方法,大部分都是从类的根路径下开始加载

相关推荐
言德斐5 小时前
SQL性能优化的思路及策略
数据库·sql·性能优化
码界奇点5 小时前
Django视图从基础到高级的全面解析
数据库·django·sqlite·web·python3.11
Allan_20256 小时前
数据库学习
数据库·学习
fen_fen6 小时前
人大金仓数据库kingbase8创建表示例
数据库·oracle
一勺菠萝丶6 小时前
「您的连接不是私密连接」详解:为什么 HTTPS 证书会报错,以及如何正确配置子域名证书
数据库·网络协议·https
²º²²এ松6 小时前
蓝牙低功耗(BLE)通信的中心设备/外围设备(连接角色)、主机/从机(时序角色)、客户端/服务器(数据交互角色)的理解
运维·服务器·数据库
百锦再6 小时前
Vue Scoped样式混淆问题详解与解决方案
java·前端·javascript·数据库·vue.js·学习·.net
数据库知识分享者小北7 小时前
云栖重磅|瑶池数据库:从云原生数据底座向“AI就绪”的多模态数据底座演进
数据库·人工智能·云原生
_Johnny_7 小时前
Redis 升级操作指南:单机与主从模式
数据库·redis·缓存
源力祁老师7 小时前
ODOO数据文件(XML、CSV、SQL)是如何转换并加载到 Odoo 数据库
xml·数据库·sql