Mybatis 系列全解(1)——全网免费最细最全,手把手教,学完就可做项目!

news2024/11/25 5:37:35

Mybatis 系列全解(1)

  • 1. 第一个小程序
  • 2. CURD 增删改查
  • 3. 模糊查询
  • 4. 配置解析
    • 4.1 核心配置文件
    • 4.2 环境配置
    • 4.3 属性
    • 4.4 类型别名
    • 4.5 设置
    • 4.6 映射器 mappers

1. 第一个小程序

1)创建一个数据库,一个表,填入一些数据。(这里不做演示,可以参考我前面写的数据库文章有具体介绍:在介绍DDL数据库操作中有创建数据库代码,链接:DDL数据库操作,或者在介绍数据库的约束中举例介绍了加上约束创建数据库,链接:约束)。

2)新建一个普通的maven项目

3)删除src项目

4)搭建环境

  • 在pom.xml中导入依赖:
<dependencies>
	<dependency>
		<groupId>mysql</groupId>
		<artifactId>mysql-connector-java</artifactId>
		<version>5.1.6</version>
	</dependency>
	
	<dependency>
		<groupId>org.mybatis</groupId>
		<artifactId>mybatis</artifactId>
		<version>3.5.1</version>
	</dependency>

	<dependency>
		<groupId>junit</groupId>
		<artifactId>junit</artifactId>
		<version>4.12</version>
		<scope>test</scope>
	</dependency>
</dependencies>

5)创建一个module模块(子模块)

  • 编写mybatis的核心配置文件

    在resources下创建mybatics-config.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"/>
			<dataSource type="POOLED">
			<property name="driver" value="com.mysql.jdbc.Driver"/>
			<property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSl=true&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
			<property name="username" value="root"/>
			<property name="password" value="root"/>
			</dataSource>
		</environment>
	</environments>

<mappers>
	<mapper resource="com/kuang/dao/UserMapper.xml"/>
</mappers>
</configuration>

       注:mappers 标签不写会报错“Type interface com.kuang.dao.UserDao is not known to the MapperRegistry”

  • main-java下创建com-kuang-dao pojo 和utils文件夹 在utils下创建工具类MybaticsUtils
package com.kuang.utils;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.apache.ibatis.session.defaults.DefaultSqlSessionFactory;
import java.io.IOException;
import java.io.InputStream;

//sqlSessionFactory ----->sqlSession
public class MybatisUtils {
//提高作用域
private static SqlSessionFactory sqlSessionFactory;
static {
	try {
		//使用mybatis第一步 :获取sqlSessionFactory对象
		String resource = "mybatis-config.xml";
		InputStream inputStream = Resources.getResourceAsStream(resource);
		sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
	}catch (IOException e) {
		e.printStackTrace();
	}
}
//既然有了sqlSessionFactory 顾名思义就可以从中获得sqlsession的实例
//Sqlsession完全包含了面向数据库执行SQL命令所需的所有方法
public static SqlSession getSqlSession() {
	return sqlSessionFactory.openSession();
}
}
  • 在pojo下创建User 根据数据库创建有参无参 getter/setter toString等

  • 在dao下创建接口UserDao

package com.kuang.dao;
import com.kuang.pojo.User;
import java.util.List;
public interface UserDao {
	List<User> getUserList();
}
  • 在dao下创建UserMapper.xml
<?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">
<!-- namespace 绑定一个对应的Dao/Mapper接口-->
<mapper namespace="com.kuang.dao.UserDao">
<!--select查询语句-->
<select id="getUserList" resultType="com.kuang.pojo.User">
	select * from mybatis.user
</select>
</mapper>

       resultMap是集合,返回多个 resultType是返回一个。

6)测试(为了工整与创建文件夹一样的格式 )

在这里插入图片描述

  • UserDaoTest里写入
package com.kuang.dao;
import com.kuang.pojo.User;
import com.kuang.utils.MybatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import java.util.List;
public class UserDaoTest {
	@Test
	public void test(){
	//第一步 获得sqlsession对象
		SqlSession sqlSession = MybatisUtils.getSqlSession();
		//方式一 getMapper
		UserDao userDao = sqlSession.getMapper(UserDao.class);
		List<User> userList = userDao.getUserList();
		
		for(User user:userList){
		System.out.println(user);
		}
		sqlSession.close();
	}
}

       可能遇到的问题1:Type interface com.kuang.dao.UserDao is not known to the MapperRegistry
因为没有在核心配置文件中配置mapper

       可能遇到的问题2:maven资源导出失败的问题。在主模块和子模块的pom.xml中写入:

<build>
	<resources>
		<resource>
		<directory>src/main/java</directory>
		<includes>
			<include>**/*.xml</include>
			<include>**/*.properties</include>
		</includes>
		</resource>
		
		<resource>
		<directory>src/main/resources</directory>
		<includes>
			<include>**/*.xml</include>
			<include>**/*.properties</include>
		</includes>
		</resource>
	</resources>
</build>

       记得刷新maven或者关掉软件再打开。

       可能遇到的问题3:绑定接口错误。

       可能遇到的问题4:返回类型不对。

       可能遇到的问题5:方法名不对。

       可能遇到的问题6:resource路径对应的是/分开。

2. CURD 增删改查

1)nameplace

nameplace中的包名必须和Dao/Mapper接口的包名一致。

2)select

       选择查询语句。

       id:就是对应的nameplace的方法名。

       resultType:sql语句执行的返回值。

       parameterType:参数类型。

3)增删改查过程:

  • 编写接口
//插入一个用户
int addUser(User user);
  • 编写对应的mapper中的sql语句(select/insert/delect/update)
<insert id="addUser" parameterType="com.kuang.pojo.User">
	insert into mybatis.user(id,name,pwd) values (#{id},#{name},#{pwd});
</insert>
  • 测试
@Test
public void addUser(){
	SqlSession sqlSession = MybatisUtils.getSqlSession();
	UserMapper mapper = sqlSession.getMapper(UserMapper.class);
	int number = mapper.addUser(new User(4,"王先正","123456"));
	if (number > 0) {
		System.out.println("插入成功!");
	}
	sqlSession.commit();
	sqlSession.close();
}

       注意: 增删改需要提交事务不然不能改数据库的的内容:sqlSession.commit();

3. 模糊查询

  • java代码执行的时候,传递通配符% _
List<User> userList = mapper.getUserLike("%王%");

       解析:

       中间为王的姓名。

       王% 以王开头的姓名 %王 最后为王的姓名 _是一个字符。

  • 在sql拼接中使用通配符!!!
<select id="getUserLike" resultType="com.kuang.pojo.User">
	select * from mybatis.user where name like #{value}"%";
</select>

4. 配置解析

4.1 核心配置文件

  • mybatis.config.xml

  • MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息。

  • configuration(配置)

  • properties(属性)

  • settings(设置)

  • typeAliases(类型别名)

  • typeHandlers(类型处理器)

  • objectFactory(对象工厂)

  • plugins(插件)

  • environments(环境配置)
           environment(环境变量)
                  transactionManager(事务管理器)
                  tdataSource(数据源)

  • databaseIdProvider(数据库厂商标识)

  • mappers(映射器)

4.2 环境配置

  • Mybatis可以配置成适应多种环境

  • 尽管可以配置多个环境,但每个sqlsessionfactory实例只能选择一种环境(environments
    中default可以选择相关environment的id)

  • Mybatis默认的事务管理器就是JDBC 连接池是POOLED

  • 学会使用多套运行环境

       注意一些关键点:

  • 默认使用的环境 ID(比如:default=“development”)。

  • 每个 environment 元素定义的环境 ID(比如:id=“development”)。

  • 事务管理器的配置(比如:type=“JDBC”)

  • 数据源的配置(比如:type=“POOLED”)

       默认环境和环境 ID 顾名思义。 环境可以随意命名,但务必保证默认的环境 ID 要匹配其中一个环境 ID。

4.3 属性

  • 这些属性可以在外部进行配置,并可以进行动态替换。你既可以在典型的 Java 属性文件中配置这些属性,也可以在 properties元素的子元素中设置。(db.properties)

  • 在recourse下编写一个配置文件db.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=UTF-8
username=root
password=root
  • 再把mybatis-config.xml中改为
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
<!--再引入外部配置文件-->
<properties resource="db.properties"/>

       一定要按规定的顺序写标签

       如果一个属性在不只一个地方进行了配置,那么,MyBatis 将按照下面的顺序来加载:

  • 首先读取在 properties 元素体内指定的属性

  • 然后根据 properties 元素中的 resource 属性读取类路径下属性文件,或根据 url 属性指定的路径读取属性文件,并覆盖之前读取过的同名属性

  • 最后读取作为方法参数传递的属性,并覆盖之前读取过的同名属性

       因此,通过方法参数传递的属性具有最高优先级,resource/url 属性中指定的配置文件次之,最低优先级的则是 properties 元素中指定的属性。(外部引用的)

4.4 类型别名

  • 类型别名可为 Java 类型设置一个缩写名字。 它仅用于 XML 配置,意在降低冗余的全限定类名书写

  • 和propeties标签一样一定要按规则写人

  • typeAlias和package

//为java类型设置一个短名字
<typeAliases>
<typeAlias type="com.kuang.pojo.User" alias="User"/>
//指定一个包名
<package name="com.kuang.pojo" />

       在没有注解的情况下,会使用 Bean 的首字母小写的非限定类名来作为它的别名。

       第一种可以自定义别名 第二种不行,若非要改则需要在实体上增加注解,使用其注解值。

@Alias("hello")
public class User {

       java类型内建的类型别名,不区分大小,采取特殊命名风格:映射类型int–>别名_int 映射类型Integer–>别名int 等。

4.5 设置

       这是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为。

在这里插入图片描述

4.6 映射器 mappers

       MapperRegistry:注册绑定我们的Mapper文件;

  • 方式一 使用相对于类路径的资源引用 (resour测对应/)推荐使用
<mapper resource="com/kuang/dao/UserMapper.xml"/>
  • 方式二 使用映射器接口实现类的完全限定类名(class对应。)
<mapper class="com.kuang.dao.UserMapper"/>

       注意点:接口和他的Mapper配置文件必须同名!

       接口和他的Mapper配置文件必须在同一个包下。

方式三 使用扫描包进行注入绑定
<package name = "com.kuang.dao">

       注意点和方式二一样!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1849580.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

uni app 树状结构数据展示

树状数据展示&#xff0c;可以点击item 将点击数据给父组件 &#xff0c;满足自己需求。不喜勿喷&#xff0c;很简单可以根据自己需求改哈&#xff0c;不要问&#xff0c;点赞收藏就好。其实可以和上一篇文章uni app 自定义 带popup弹窗的input组件-CSDN博客结合使用&#xff…

LabVIEW项目管理中如何平衡成本、时间和质量

在LabVIEW项目管理中&#xff0c;平衡成本、时间和质量是实现项目成功的关键。通过制定详细的项目计划、合理分配资源、严格控制进度、进行质量保证和灵活应对变化&#xff0c;项目管理者可以有效地协调这三者的关系&#xff0c;确保项目按时、按质、按预算完成。 1. 制定详细…

Reid系列论文学习——换装Reid

今天要学习的有关Reid的论文是2019年提出的一篇名为&#xff1a;Beyond Scalar Neuron: Adopting Vector-Neuron Capsules for Long-Term Person Re-Identification. 论文链接&#xff1a;https://opus.lib.uts.edu.au/bitstream/10453/137156/4/Binder1.pdf Code链接&#x…

搜索python包的说明

当我发现bug时&#xff0c;就怀疑是sns包的版本问题了&#xff08;原代码是原作者以前成功运行的代码&#xff09;&#xff0c;于是直接到网上搜&#xff0c;找到对应的说明文档 根据该示例代码进行改写&#xff1a; 达成目的。

Elasticsearch 数据提取 - 最适合这项工作的工具是什么?

作者&#xff1a;来自 Elastic Josh Asres 了解在 Elasticsearch 中为你的搜索用例提取数据的所有不同方式。 对于搜索用例&#xff0c;高效采集和处理来自各种来源的数据的能力至关重要。无论你处理的是 SQL 数据库、CRM 还是任何自定义数据源&#xff0c;选择正确的数据采集…

2024年全国青少信息素养大赛python编程复赛集训第八天编程题分享

整理资料解析答案非常不容易,感谢各位大佬给个点赞和分享吧,谢谢 今天题目较难:适合初中组 大家如果不想阅读前边的比赛内容介绍,可以直接跳过:拉到底部看集训题目 (一)比赛内容: 【小学组】 1.了解输入与输出的概念,掌握使用基本输入输出和简单运算 为主的标准函…

进程、线程的区别

进程、线程的关系 开工厂生产手机&#xff0c;制作一条生产线&#xff0c;这个生产线上有很多的器件以及材料。一条生产线就是一个进程。 只有生产线是不够的&#xff0c;使用找五个工人来进行生产&#xff0c;这个工人能够利用这些材料最终一步步的将手机做出来&#xff0c;这…

上位机图像处理和嵌入式模块部署(mcu之静态库生成和使用)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 很多同学做了很长时间的mcu和keil开发&#xff0c;都认为keil工程中必须包含所有的源代码&#xff0c;其实这是不对的。如果有一些代码我们不希望别…

C#.net6.0+Vue+Ant-Design智慧医院手术麻醉系统源码 手术麻醉软件信息化管理系统 麻醉文书祥解

C#.net6.0VueAnt-Design智慧医院手术麻醉系统源码 手术麻醉软件信息化管理系统 麻醉文书祥解 医护人员通过手麻信息系统可以进行手术的预约申请、受理、安排&#xff0c;从门诊医生下医嘱到发起手术申请、护士长审核通过&#xff0c;均实现了全流程信息化管理&#xff0c;大大…

内容安全复习 4 - 深度生成模型

文章目录 概述经典算法自回归模型&#xff08;Autoregressive model&#xff09;变分自编码器&#xff08;VAE&#xff09;生成对抗网络&#xff08;GAN&#xff09;扩散模型&#xff08;Diffusion model&#xff09;总结 应用 概述 深度生成模型是一类使用深度学习技术构建的…

【第25章】Vue实战篇之用户登出

文章目录 前言一、后端代码二、前端代码1.接口调用2.界面代码3.事件代码 三、效果总结 前言 这里来演示用户登出。 一、后端代码 /*** 登出* param token token* return Result*/RequestMapping("logout")public Result logout(RequestHeader("Authorization&…

【Python】从基础到进阶(一):了解Python语言基础以及变量的相关知识

&#x1f525; 个人主页&#xff1a;空白诗 文章目录 引言一、Python简介1.1 历史背景1.2 设计哲学1.3 语言特性1.4 应用场景1.5 为什么选择Python 二、Python语言基础2.1 注释规则2.1.1 单行注释2.1.2 多行注释2.1.3 文件编码声明注释 2.2 代码缩进2.3 编码规范2.3.1 命名规范…

镜像发布至dockerHub

1、login 没有账号的话去注册一个 https://hub.docker.com docker login 输入账号密码和账号2、修改镜像名格式 可以直接招我的修改 格式为你的 hub名/镜像名 3、推送

2D图形引擎Cairo例子

代码; #include<cairo.h> int main() {cairo_surface_t *surface;cairo_t *cr;surfacecairo_image_surface_create(CAIRO_FORMAT_ARGB32,320,240);crcairo_create(surface);cairo_set_source_rgb(cr,0,1,0);cairo_rectangle(cr,10,10,200,200);cairo_fill(cr);cairo_mov…

OpenMVS算法流程

OpenMVS安装使用教程 源码与注释代码地址 . 源码: GitHub - cdcseacave/openMVS: open Multi-View Stereo reconstruction library . 注释代码: GitHub - electech6/openMVS_comments: open Multi-View Stereo reconstruction library 依赖项与安装工具说明 OpenMVS 依赖的…

分享一个 Fail2ban 过滤规则

今天明月给大家分享个 Fail2ban 的过滤&#xff08;Filter&#xff09;规则&#xff0c;有关 Fail2ban 的文章大家可以参考【服务器全面使用 Fail2Ban 初见成效】和【使用 Fail2ban 禁止垃圾采集爬虫&#xff0c;保护 Nginx 服务器】等文了解&#xff0c;总之 Fail2ban 是 Linu…

求解FAT表大小

540M/1K 540k 540 * 1024 b 512k对应2的19次方<540k<1024k对应2的20次方 取比540k大的1024k 八位一个字节 20对应2.5个字节 所以FAT占用 2.5*5401350k 1.2G/1k1.2M 1M1024k对应2的20次方<1.2M<2M对应2的21次方 取2M 21/8是循环小数不可以直接用 所以四舍五…

hdfs高可用文件系统架构

1、整体架构 2、角色简介 2.1、namenode NameNode 是 HDFS 集群中的核心组件&#xff0c;负责管理文件系统的元数据、处理客户端请求、管理数据块、确保数据完整性和高可用性。由于其重要性&#xff0c;NameNode 的性能和可靠性直接影响整个 HDFS 集群的性能和可靠性。在生产…

GD32 MCU的选项字节是什么?

GD32 MCU的选项字节是什么&#xff0c;有什么功能呢&#xff1f;选项字节被误篡改如何回复&#xff1f; 读者朋友们是否会有以上的疑问&#xff0c;首先我们先为大家介绍选项字节是什么以及选项字节的功能。 以GD32F30X系列MCU为例&#xff0c;其选项字节说明如下表所示&…

Acrobat Pro DC 2021:Mac/Win平台上全面高效的PDF编辑器

Acrobat Pro DC 2021是一款在Mac和Windows平台上广受欢迎的PDF编辑器&#xff0c;它凭借其全面的功能和高效的性能&#xff0c;为用户提供了卓越的PDF处理体验。 一、编辑功能全面强大 Acrobat Pro DC 2021允许用户轻松创建、编辑、合并、转换、签署和分享PDF文件。无论是对P…