Python 官方文档:入门教程 => 点击学习
目录前言mybatis简介优点缺点搭建第一个Mybatis程序新建项目。引入pom.xml依赖。新建数据库数据表。新建Student实体类。配置Mybatis的配置文件。创建Stud
我们关于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代理的方式进行操作。喜欢的小伙伴们多多支持,你们的支持就是我更新的动力。
到此这篇关于Mybatis入门指南之实现对数据库增删改查的文章就介绍到这了,更多相关Mybatis对数据库增删改查内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Mybatis入门指南之实现对数据库增删改查
本文链接: https://lsjlt.com/news/170385.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0