Mybatis入门指南之实现对数据库增删改查
人间烟火617 人气:0前言
我们关于Spring和Spring MVC的学习也有一段时间了,都还没有进行过数据库的操作,而在实际项目中数据库是必不可少的部分,所以我们接下来将来学习Mybatis框架来对数据库进行一些操作。
MyBatis
简介
Mybatis原本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation迁移到了google code,并且改名为MyBatis,2013年11月迁移到Github。Mybatis是一个实现了数据持久化的开源框架,简单理解就是对JDBC进行封装封装再封装。
所以当看到iBatis的时候我们就应该知道,iBatis就是Mybatis。现在还有很多我们引入的包名还是写的是iBatis。
优点
- 与JDBC相比,减少了50%以上的代码量。
- Mybatis是最简单的持久化框架,小巧并且简单易学。
- Mybatis灵活,不会对应用程序或者数据库的现有设计强加任何影响,SQL写在XML里,从程序代码中彻底分离,降低耦合度,便于统一管理和优化,可重用。
- 提供XML标签,支持编写动态SQL语句(XML中使用if, else)。
- 提供映射标签,支持对象与数据库的ORM字段关系映射(在XML中配置映射关系,也可以使用注解)。
缺点
- SQL语句的编写工作量较大。
- SQL语句依赖于数据库,导致数据库移植性差,不能随意更换数据库。
搭建第一个Mybatis程序
新建项目。
自定义项目名,我这里定义为myBatisDemo。
引入pom.xml依赖。
<dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.9</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.30</version> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.24</version> </dependency>
我们需要引入mybatis依赖、mysql依赖和lombok依赖。
lombok依赖我们前面就使用过,我们可以简化实体类的开发。而mybatis依赖和mysql依赖是我们数据库的依赖。
新建数据库数据表。
我们对数据库进行操作首先就要有数据库。所以我们来新建一个数据库。我们这里使用工具创建,不需要手敲SQL命令。
新建一个数据库名为test,库中建一个名为Students的数据表。
现在我们的表中还没有数据,等下我们使用代码来对数据库进行增删改查的操作。
新建Student实体类。
package com.xyj.entity; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; @Data @AllArgsConstructor @NoArgsConstructor public class Student { private long id; private String name; private int age; }
我们实体类中的属性要对应我们数据库表中的字段。
配置Mybatis的配置文件。
在resources资源文件夹下面创建config.xml配置文件。
在comfig.xml文件中添加以下配置:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"></transactionManager> <dataSource type="POOLED"> <property name="driver" value="com.mysql.cj.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/test? useUnicode=true&characterEncoding=UTF-8"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource> </environment> </environments> </configuration>
driver、url、username、password分别对应数据库驱动、路径、用户名和密码。
创建StudentMapper.xml文件。
我们在开发中需要为每个实体类创建mapper文件,我们需要在其中写我们对该该实体类进行操作的SQL语句。
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.xyj.mapper.StudentMapper"> <!-- 增 --> <insert id="add" parameterType="com.xyj.entity.Student"> insert into students (id,name,age) values (#{id},#{name},#{age}) </insert> <!-- 删 --> <delete id="delete" parameterType="int"> delete from students where id = #{id}; </delete> <!-- 改 --> <update id="update" parameterType="com.xyj.entity.Student"> update students set age = #{age} where id = #{id} </update> <!-- 查 --> <select id="query" resultType="com.xyj.entity.Student"> select * from students </select> </mapper>
在mapper文件中增删改查对应的标签为insert
、delete
、update
、select
。标签中id
是我们之后调用的名字,parameterType
表示我们需要传递的值的类型。我们这里传值使用#{}
的格式。
在config.xml中加入mapper。
<mappers> <mapper resource="com/xyj/mapper/StudentMapper.xml"></mapper> </mappers>
调用Mybitis原生接口进行操作
public static void main(String[] args) { InputStream inputStream = Test.class.getClassLoader().getResourceAsStream("config.xml"); SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder(); SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(inputStream); SqlSession sqlSession = sqlSessionFactory.openSession(); }
我们首先使用输入流对config.xml文件进行读取,然后使用sqlSessionFactoryBuilder
的build
方法创建sqlSessionFactory
,再用sqlSessionFactory
的openSession
方法创建sqlSession
。
增
Student student1 = new Student(1L,"小明",16); Student student2 = new Student(2L,"小红",15); sqlSession.insert("com.xyj.mapper.StudentMapper.add",student1); sqlSession.insert("com.xyj.mapper.StudentMapper.add",student2); sqlSession.commit(); sqlSession.close();
调用sqlSession
的insert
方法,传入第一个参数为我们实体类对应mapper文件中对应的操作id
,第二个参数为数据。
我们执行完sql之后还需要提交事务,最后释放资源。
执行结果:
成功在数据表中添加了两条数据。
删
sqlSession.delete("com.xyj.mapper.StudentMapper.delete",2);
我们这里调用delete
方法,删除id
为2的学生数据。
执行结果:
删除成功!
改
Student student = new Student(1L,"小刚",19); sqlSession.update("com.xyj.mapper.StudentMapper.update",student);
调用update
方法修改数据。
执行结果:
修改数据成功!
查
我们再添加两条数据。
List<Student> studentList = sqlSession.selectList("com.xyj.mapper.StudentMapper.query"); System.out.println(studentList);
我们用List接收查询的数据再打印出来。
打印结果:
[Student(id=1, name=小刚, age=19), Student(id=2, name=小明, age=15), Student(id=3, name=小红, age=17)]
查询成功!
总结
关于Mybatis入门配置以及使用原生接口进行增删改查操作就是这样,接下来的内容我将来讲解Mapper代理的方式进行操作。喜欢的小伙伴们多多支持,你们的支持就是我更新的动力。
加载全部内容