【2023.11.24】Mybatis基本连接语法学习➹
基本配置
1.如果使用Maven管理项目,需要在pom.xml中配置依赖。
2.安装Mybatis-3.5.7.jar包
3.进行XML配置:这里将文件命名为mybatis-config.xml
配置数据库连接XML文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//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="${驱动类(含包名)}"/><property name="url" value="${数据库连接URL}"/><property name="username" value="${用户名}"/><property name="password" value="${密码}"/></dataSource></environment></environments><mappers><mapper url = "file:src/com/test/mapper/TestMapper.xml"/><!-- 存放映射器XML文件 --></mappers></configuration>
其中mappers标签内存放XML映射器文件。
编写Java主函数
package com.test;import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.FileInputStream;
import java.io.FileNotFoundException;public class Main {public static void main(String[] args) throws FileNotFoundException {SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(new FileInputStream("src/mybatis-config.xml"));try (SqlSession sqlSession = sqlSessionFactory.openSession(true)){System.out.println(sqlSession.selectList("getArtist"));//括号内填写SQL映射语句的id}}
}
1.从 XML 中构建 SqlSessionFactory
每个基于 MyBatis 的应用都是以一个 SqlSessionFactory 的实例为核心的。SqlSessionFactory 的实例可以通过 SqlSessionFactoryBuilder 获得,创建SqlSessionFactory时会调用xml配置文件。
2.从 SqlSessionFactory 中获取 SqlSession
我们可以从中获得 SqlSession 的实例。SqlSession 提供了在数据库执行 SQL 命令所需的所有方法。
你可以通过 SqlSession 实例来执行已映射的 SQL 语句。SQL语句的映射需要编写映射器XML文件。
编写映射器(mapper)的XML文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="src/com/test/mapper/TestMapper.xml"><!--区分不同映射器--><!--条件查询--><select id="getArtist" resultType="String">select aName from artist<!--填写SQL语句,里面的变量都是数据库的表名和字段名--></select>
</mapper>
注:若xml配置文件中出现找不到映射器文件的情况,注意配置文件中mapper标签内的映射器引用格式。
接口函数
编写映射器接口:
package com.test.mapper;import com.test.artist;import java.util.List;public interface TestMapperInterface {List<artist> selectArtist();artist getArtistById(int a);int addArtist(artist newArtist);int deleteArtist(int d);
}
要让映射器关联上映射器接口,只需要修改映射器的namespace为接口地址:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.test.mapper.TestMapperInterface"><resultMap id="test" type="com.test.artist"><result column="aID" property="aID"/></resultMap><select id="selectArtist" resultMap="test">select * from artist</select><!--条件查询--><select id="getArtistById" resultMap="test">select * from artist where aID = #{a}<!--接口形参名--></select><!--插入操作--><insert id="addArtist">insert into artist(aID,aName,asex) values (#{aID},#{aName},#{asex})</insert><!--删除操作--><delete id="deleteArtist" parameterType="com.test.artist">delete from artist where aID = #{d}</delete></mapper>
接口中的方法会自动对应上映射器中的SQL执行语句id
修改配置文件中的mapper路径:
<mapper resource = "com/test/mapper/TestMapper.xml"/>
主函数调用映射器接口:
package com.test;import com.test.mapper.TestMapperInterface;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.FileInputStream;
import java.io.FileNotFoundException;public class Main {public static void main(String[] args) throws FileNotFoundException {SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(new FileInputStream("src/mybatis-config.xml"));try (SqlSession sqlSession = sqlSessionFactory.openSession(true)){TestMapperInterface mapper = sqlSession.getMapper(TestMapperInterface.class);mapper.selectArtist().forEach(System.out::println);System.out.println("\n");System.out.println(mapper.getArtistById(2089));}}
}
MyBatis与JDBC的差异


| JDBC和Mybatis优缺点对比 | |
| JDBC | Mybatis |
| 用DriverManager驱动类连接数据库,java代码与数据库耦合 | 在配置xml文件中连接数据库,使得java代码与数据库分离 |
| 在Statement对象中执行SQL语句,java代码与SQL语句耦合 | 在映射器的xml文件中执行SQL语句,使得java代码与SQL语句分离 |
| 在ResultSet对象中接收SQL语句结果,每条结果需要指针遍历。 | 直接通过SqlSession中的方法接收SQL语句结果,结果是一个集合。 |
综上,相比于JDBC所有功能都在java代码中执行,Mybatis尽管结构更加复杂,但每个文件负责不同的功能,更加便于管理。
相关文章:
【2023.11.24】Mybatis基本连接语法学习➹
基本配置 1.如果使用Maven管理项目,需要在pom.xml中配置依赖。 2.安装Mybatis-3.5.7.jar包 3.进行XML配置:这里将文件命名为mybatis-config.xml 配置数据库连接XML文件 <?xml version"1.0" encoding"UTF-8" ?> <!DO…...
如何防止网络被入侵?
随着互联网的普及,网络安全问题越来越受到人们的关注。其中,如何防止网络被入侵是一个重要的问题。本文将介绍一些防止网络被入侵的方法,帮助大家保护自己的网络安全。 一、使用强密码 强密码是防止网络被入侵的第一道防线。一个好的密码应该…...
【Linux】常见指令及周边知识(一)
【Linux】常见指令及周边知识(一) 一、初始Linux操作系统1.Linux背景2.如何使用Linux 二、学习Linux之前的预备周边知识(重点):1.什么叫做文件?2. Linux下的路径分隔符3.在Linux中为什么会存在路径…...
【Docker】从零开始:6.配置镜像加速器
【Docker】从零开始:5.配置镜像加速器 什么是镜像加速器?为什么要配置docker镜像加速器?常见的Docker镜像加速器有哪些?如何申请Docker镜像加速器如何配置Docker镜像加速器 什么是镜像加速器? 镜像加速器是一个位于Docker Hub之…...
The Bridge:从临床数据到临床应用(预测模型总结)
The Bridge:从临床数据到临床应用(预测模型总结) 如果说把临床预测模型比作临床数据和临床应用之间的一座“桥梁”,那它应该包括这样几个环节:模型的构建和评价、模型的概率矫正、模型决策阈值的确定和模型的局部再评价。 模型的构…...
[极客大挑战 2019]Secret File1
[极客大挑战 2019]Secret File1 在bp里面发现secr3t.php 将secr3t.php 直接加在网站后面,发现了有关flag的信息,一个flag.php文件 在遇到flag.php时候,联想到php伪协议,构造伪协议方式 secr3t.php?filephp://filter/readconver…...
如何评估一个论坛或峰会值不值得参加?
现在的论坛和峰会非常多,且都宣传的非常高端,很多人为了不错过机会像赶场一样总在参会路上。但究竟什么样的论坛或峰会才值得一去呢? 评估一个论坛或峰会是否值得参加,需要考虑多个因素。 1、主题与你的兴趣或职业相关性…...
04_使用API_日期和时间
JDK 8 之前传统的日期、时间 Date 类 代表的是日期和时间 import java.util.Date;public class Test {public static void main(String[] args) {// 1. 创建一个Data对象,代表系统当前时间信息的Date d new Date();System.out.println(d); // 输出的是日期与当…...
手动实现 git 的 git diff 功能
这是 git diff 后的效果,感觉挺简单的,不就是 比较新旧版本,新增了就用 "" 显示新加一行,删除了就用 "-" 显示删除一行,修改了一行就用 "-"、"" 显示将旧版本中的该行干掉了并…...
RabbitMQ之MQ的可靠性
文章目录 前言一、数据持久化交换机持久化队列持久化消息持久化 二、LazyQueue控制台配置Lazy模式代码配置Lazy模式更新已有队列为lazy模式 总结 前言 消息到达MQ以后,如果MQ不能及时保存,也会导致消息丢失,所以MQ的可靠性也非常重要。 一、…...
Navicat 技术指引 | 适用于 GaussDB 的查询编辑器
Navicat Premium(16.2.8 Windows版或以上) 已支持对 GaussDB 主备版的管理和开发功能。它不仅具备轻松、便捷的可视化数据查看和编辑功能,还提供强大的高阶功能(如模型、结构同步、协同合作、数据迁移等),这…...
Jenkins+Maven+Gitlab+Tomcat 自动化构建打包、部署
JenkinsMavenGitlabTomcat 自动化构建打包、部署 1、环境需求 本帖针对的是Linux环境,Windows或其他系统也可借鉴。具体只讲述Jenkins配置以及整个流程的实现。 1.JDK(或JRE)及Java环境变量配置,我用的是JDK1.8.0_144࿰…...
(2023码蹄杯)省赛(初赛)第三场真题(原题)(题解+AC代码)
题目1:MC0227堆煤球 码题集OJ-堆煤球 (matiji.net) 思路: 1.i从l枚举到r,i是8的倍数就跳过,i不是8的倍数就用等差数列求和公式i(1i)/2,最后累加到答案中即可 AC_Code:C #include<bits/stdc.h> using namespace std;int main( ) {in…...
第十二章 : Spring Boot 日志框架详解
第十二章 : Spring Boot 日志框架详解 前言 本章知识重点:介绍了日志诞生背景,4种日志框架:Logback、Log4j、Log4j2和Slf4j的优劣势分析,以及重点介绍了log4j2的应用示例以及配置,以及日志框架应用中遇到常见的问题以及如何处理。 背景 Java日志框架的发展历程可以追…...
STM32 -Bin/Hex文件格式解析
文章目录 1. 概述2. Hex文件2.1 格式解析2.2 数据类型2.3 举例解析2.4 合并两个Hex文件方法 3. Bin文件3.1 生成方式3.2 合并多个Bin文件方法3.3 打开Bin文件方式3.4 和Hex文件比较 4 总结 1. 概述 Hex文件:它是单片机和嵌入式工程编译输出的一种常见的目标文件格式…...
【Java 进阶篇】Redis:打开缓存之门
介绍 Redis(Remote Dictionary Server)是一个高性能的键值对存储系统,被广泛用作缓存、消息中间件和数据库。它以其快速的读写能力、支持多种数据结构和丰富的功能而闻名。在这篇博客中,我们将深入了解Redis的概念、安装以及基本…...
Python与设计模式--享元模式
10-Python与设计模式–享元模式 一、网上咖啡选购平台 假设有一个网上咖啡选购平台,客户可以在该平台上下订单订购咖啡,平台会根据用户位置进行 线下配送。假设其咖啡对象构造如下: class Coffee:name price 0def __init__(self,name):se…...
亚马逊云科技向量数据库助力生成式AI成功落地实践探秘(二)
向量数据库选择哪种近似搜索算法,选择合适的集群规模以及集群设置调优对于知识库的读写性能也十分关键,主要需要考虑以下几个方面: 向量数据库算法选择 在 OpenSearch 里,提供了两种 k-NN 的算法:HNSW (Hierarchical…...
怎么当代课老师教学生
老师朋友们,有没有帮忙当过代课老师呢?或者,没当过的老师是不是对这种职业充满了好奇?让我来分享一下,当代课老师的日常是什么样的吧! 备课 说起备课,那可是个大工程!不过ÿ…...
『 MySQL数据库 』表的增删查改(CRUD)之表的数据插入及基本查询
文章目录 📂 Create(创建/新增)📌全列插入与指定列插入📌📌单行数据插入与多行数据插入📌📌插入数据否则更新📌📌数据的替换📌 📂 Retrieve(查询)Ὄ…...
终极指南:深入理解Swagger-Node核心组件与工作原理
终极指南:深入理解Swagger-Node核心组件与工作原理 【免费下载链接】swagger-node Swagger module for node.js 项目地址: https://gitcode.com/gh_mirrors/sw/swagger-node Swagger-Node是Node.js生态中一款强大的API开发工具,它通过直观的YAML配…...
RePKG:Wallpaper Engine资源处理的终极工具指南
RePKG:Wallpaper Engine资源处理的终极工具指南 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg RePKG是一款专为Wallpaper Engine设计的强大资源处理工具,能…...
因漏洞数量激增,NIST 已停止对低优先级漏洞的评分
聚焦源代码安全,网罗国内外最新资讯!编译:代码卫士由于漏洞提交量不断增加导致工作量日益增长,美国国家标准与技术研究院 (NIST) 上周宣布从2026年4月15日起,停止为优先级较低的安全漏洞分配严重性评分。自4月15日起&a…...
期货反向跟单: 千万不要教小白单一技术。
做期货反向跟单的都知道,咱们找小白盘手,图的就是他们没经验、容易踩坑。但好多人培训小白时犯了个致命错 — 只教一种技术,还逼着他们死记硬背严格执行,结果发现:小白执行力是上来了,可咱们跟单却亏得一塌…...
DAMO-YOLO入门指南:理解COCO 80类标准与达摩院扩展类别的映射关系
DAMO-YOLO入门指南:理解COCO 80类标准与达摩院扩展类别的映射关系 你是不是刚接触DAMO-YOLO,看着它强大的目标检测能力很兴奋,但一看到“COCO 80类”和“达摩院扩展类别”这些术语就有点懵?别担心,这种感觉我刚开始也…...
如何防止SQL触发器导致事务超时_拆分逻辑为异步队列处理
触发器中禁止耗时操作,应改用异步方案:MySQL用消息表轮询,PostgreSQL优先用LISTEN/NOTIFY;需保障幂等、唯一ID、上下文完整及超时重试。触发器里直接调用耗时操作必然拖垮事务SQL 触发器运行在主事务上下文中,INSERT/U…...
别再死磕卡尔曼滤波了!用Python从零实现一个RBPF粒子滤波建图(附避坑指南)
从零实现RBPF粒子滤波建图:Python实战与避坑指南 在机器人定位与建图(SLAM)领域,粒子滤波方法因其对非线性系统的天然适应能力而备受青睐。但大多数教程停留在理论推导,真正动手实现时总会遇到各种"魔鬼细节"。本文将用Python带你完…...
F12抓包实战:从浏览器Network面板到接口调试全解析
1. 浏览器F12抓包入门指南 第一次接触F12开发者工具时,我也被满屏的数据搞得头晕眼花。记得有次测试电商网站的购物车功能,开发同事请假了,文档也没更新,我只能硬着头皮用F12自己找接口。现在回想起来,掌握这个技能真…...
不止于下载:用Python脚本把you-get和ffmpeg串起来,实现自动追更UP主音频合集
打造智能音频收藏系统:Python整合you-get与ffmpeg实现UP主作品自动归档 每次发现喜欢的知识分享UP主更新内容时,你是否也遇到过这样的困扰:想反复聆听其中的精华片段,却不得不反复打开视频平台;收藏的优质内容分散在不…...
这5款工具让你的研究生之路更轻松
作为一名在科研领域摸爬滚打多年的从业者,我深知工具选对能事半功倍,选错则耗时耗力。今天就把私藏的科研神器毫无保留地分享给大家,全部亲测好用!1. Adobe Illustrator (AI):矢量图形的行业标准如果你是追求极致品质的…...

