Mybatis入门指南之实现对数据库增删改查
前言
我们关于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代理的方式进行操作。喜欢的小伙伴们多多支持,你们的支持就是我更新的动力。
到此这篇关于Mybatis入门指南之实现对数据库增删改查的文章就介绍到这了,更多相关Mybatis对数据库增删改查内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Springboot JPA如何使用distinct返回对象
这篇文章主要介绍了Springboot JPA如何使用distinct返回对象,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-02-02Springboot集成Springbrick实现动态插件的步骤详解
这篇文章主要介绍了Springboot集成Springbrick实现动态插件的详细过程,文中的流程通过代码示例介绍的非常详细,感兴趣的同学可以参考一下2023-06-06
最新评论