一、什么是Mybatis
MyBatis是一个持久层框架,属于JDBC的替代方案之一,他的前身是iBatis。
它属于ORM关系型映射。
ORM(O/R - Mapping 对象关系映射),是一种把内存中的对象保存到关系型数据库的技术。用它封装数据库访问的细节。采用元数据(XML)的方式来描述对象-关系(数据库表)的映射细节,可以使得ORM充当任何一个Java应用业务层到数据库之间的桥梁 。
二、为什么使用Mybatis
MyBatis 几乎免除了(简化)JDBC中那些繁琐的工作(建立连接、PreparedStatement-预编译sql、设置占位符、获取结果集等一系列),可以让开发者更多的关注SQL语句本身。
三、Mybais的组成
1.核心接口和类(SqlSessionFactory 和 SqlSession)
SqlSessionFactory:
1).是MyBatis中的核心对象,是数据库映射关系经过编译之后的内存镜像 。
2).可以根据上层对象SqlSessionFactoryBuilder对象来进行创建 ;SqlSessionFactoryBuilder则可以通过核心(主)配置文件 或者Java代码定义好的配置类来构建。
3).是线程安全的,它一旦被创建,在应用的运行期间都会存在,如果我们多次创建同一个数据库的SqlSessionFactory,会导致数据库资源被消耗殆尽。因此通常情况下,同一个数据库都只会对应一个SqlSessionFactory ,所以在构建SqlSessionFactory 实例时通常会使用单例模式 。
4).作用就是用来创建SqlSession。
SqlSession:
1).是另一个核心对象,他是应用程序和持久层之间执行交互操作的单线程对象 。
2).每一个线程都应拥有一个自己的SqlSession实例,并且该实例是不共享的,同时也是线程不安全的,SqlSession它的使用范围最好限制在一次请求或者一个方法中。绝对不能够把其放在一个类的静态字段(属性),注意使用SqlSession对象后,要注意关闭资源。
3).作用主要是执行持久化操作。
2.核心(主)配置文件 mybatis.cfg.xml
1).mybatis.cfg.xml是主配置文件 ,必须要放在resources目录下 。
2).用于配置数据源,链接各种ORM映射文件,以及实体类别名、日志等.
3.SQL映射文件(mapper.xml)
1).通常是用来映射持久层接口,因此需要映射文件和它所对应的接口同名 。
2).在resources目录下,需要创建和接口(com.project.dao)所在包同名的文件夹,注意在resources目录下,如果创建目录时书写com.project.dao,此时时创建了一个名称为com.project.dao的目录,因此如需创建有层级关系的目录,需要用com/project/dao,此时才会创建出三个有层级关系的目录 。
四、使用Mybatis搭建项目
1.导入依赖(MyBatis两个和Mysql一个)
2.在项目中去加入主配置文件mybatis.cfg.xml(在此之前,实体类和持久接口以及数据库应该建立好),然后根据项目去修改主配置文件的内容
3.数据源设置
特别注意:驱动,url(端口号,数据库),数据库密码。
4.映射文件所在的位置
映射文件所在位置和持久接口在同一包下面--一般是书写持久接口所在的包 。
5.导入映射文件
1).导入映射文件前,需要在resources目录下,创建和持久接口所在包同名的目录,由于resources的特殊性,创建时用 -- / -- 表示创建的为层级目录,比如com/project/dao(创建的是com、project、dao,这三个有层级关系的目录) 。
2).导入映射文件时,需要将映射文件和需要映射的持久接口保持同名,否则无法映射 。
3).导入后,在映射文件mapper元素的namespace属性书写,持久接口全路径 。
此时 我的接口和映射文件所在目录和名称保持一致 。
随后就可在其中通过标签书写sql语句。
这是我的文件结构
如有需要Mybatis配置文件的友友可以私聊我!