我们关于Spring和Spring MVC的学习也有一段时间了,都还没有进行过数据库的操作,而在实际项目中数据库是必不可少的部分,所以我们接下来将来学习Mybatis框架来对数据库进行一些操作。
Mybatis原本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation迁移到了google code,并且改名为MyBatis,2013年11月迁移到Github。Mybatis是一个实现了数据持久化的开源框架,简单理解就是对JDBC进行封装封装再封装。
所以当看到iBatis的时候我们就应该知道,iBatis就是Mybatis。现在还有很多我们引入的包名还是写的是iBatis。
自定义项目名,我这里定义为myBatisDemo。
<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的数据表。
现在我们的表中还没有数据,等下我们使用代码来对数据库进行增删改查的操作。
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; }
我们实体类中的属性要对应我们数据库表中的字段。
在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分别对应数据库驱动、路径、用户名和密码。
我们在开发中需要为每个实体类创建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
表示我们需要传递的值的类型。我们这里传值使用#{}
的格式。
<mappers> <mapper resource="com/xyj/mapper/StudentMapper.xml"></mapper> </mappers>
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代理的方式进行操作。喜欢的小伙伴们多多支持,你们的支持就是我更新的动力。