mybatis框架搭建、mybatis打印日志设置、参数传递使用、myatis插件MyBatisX

news2024/11/15 10:58:09

一、框架

就是对技术的封装,将基础的技术进行封装,让程序员可以快速的使用,提高效率。

Java后端框架:

mybatis:对jdbc进行封装 

spring:对整个Java后端架构进行管理的

springweb:对web层(servlet)进行封装

springboot:对spring框架的搭建进行封装

二、mybatis背景

mybatis原来是apache下面的一个开源项目,名为ibatis,2010年开发团队转移到谷歌旗下,改名为mybatis。

mybatis介绍:mybatis是一个优秀的数据持久层框架(dao层  数据访问层  数据持久层)

是一个对jdbc进行的封装,避免了jdbc手动设置参数,手动映射结果的操作

mybatis将jdbc中的接口进行封装,提供了它自己的类和接口实现

可以使用xml配置和注解的方式,将数据库中记录自动映射到Java对象中,是一种ORM实现(对象关系映射)将可以自动将数据映射到对象中的这种框架,也称为ORM框架

mybatis还提供了动态sql和数据缓存

三、mybatis搭建

1、创建一个maven项目

2、导入mybatis依赖的jar包,在pom。xml中进行配置

        <!--mybatis-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.2</version>
        </dependency>

3、创建一个全局的mybatis配置文件,配置数据库连接等配置

在rescources下创建一个普通文件(mybatis.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">

<!--mybatis核心全局配置文件-->
<configuration>
<settings>
    <!--配置日志-->
    <setting name="logImpl" value="STDOUT_LOGGING"/>
    <!--开启驼峰命名自动映射-->
    <setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>
    <!--为类配置别名-->
    <typeAliases>
       <!-- <typeAlias type="com.ffyc.mybatispro.model.Admin" alias="Admin"></typeAlias>-->
        <package name="com.ffyc.mybatispro.model"/>
    </typeAliases>
       <!--配置数据库连接相关信息-->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <!--type="POOLED" 使用数据库连接池功能 ,默认创建了10个链接对象,减少频繁创建链接对象-->
            <dataSource type="POOLED">
                <!--数据库连接配置-->
                <property name="driver" value="com.mysql.cj.jdbc.Driver" />
                <property name="url" value="jdbc:mysql://127.0.0.1:3306/ssmdb?serverTimezone=Asia/Shanghai" />
                <property name="username" value="root" />
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>
    
    <!--注册映射文件-->
    <mappers>
        <mapper resource="mappers/AdminMappers.xml"></mapper>
    </mappers>
    
</configuration>

数据库连接池

连接数据库,每次访问数据库的时候,创建一个Connection用完关闭

但是访问量大了之后,每次都要创建新的连接对象,用完关闭,比较耗时

使用数据库连接池,在池(集合)中先创建一些连接对象,用户访问时,就直接池中获取一个链接对象,用完不销毁,还会池中,这样就减少频繁创建销毁对象

使用数据库连接池功能,默认创建了10个对现象,减少频繁创建连接对象

4、创建数据库创建表,创建数据

5、创建一个访问的接口

6、创建sql映射文件

在rescources下创建一个包(Mappers),包下创建一个普通文件(AdminMappers.xml)文件名可以自己进行修改

7、测试mybatis

1、读取mybatis配置文件 

 Reader reader= Resources.getResourceAsReader("mybatis.xml");
//"mybatis.xml"是对mybatis的配置文件名

2、创建 SqlSessionFactory

//2.创建SqlSessionFactory
SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);

3、创建 SqlSession

//3.创建 SqlSession
SqlSession sqlSession=sqlSessionFactory.openSession();

4、获得接口代理对象

//4创建接口代理对象
AdminDao adminDao =  sqlSession.getMapper(AdminDao.class);

sql映射文件和接口对应关系

四、 mybatis日志

配置日志

<settings>
    <setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>

 

在配置时,按照规定的顺序进行配置 

五、 参数传递

单值传递

 /*一个值传参数*/
    Admin findAdminByid(int id);
    void deleteAdmin(int id);
    Admin findAdminByAccount(String account);

 相对于的映射文件中的配置

  <select id="findAdminByid" parameterType="int" resultType="Admin">
                select * from admin where id =#{id}
</select>

  <delete id="deleteAdmin" parameterType="int">
        delete from admin where id = #{id}
    </delete>
   <select id="findAdminByAccount" parameterType="string" resultType="Admin">
         select * from admin where account =#{account}
    </select>

多值传递

使用@Param进行值的绑定

 /*多个值传参数*/
    Admin login(@Param("acc") String account,@Param("pwd") String password);

相对于的映射文件中的配置

 <select id="login" resultType="Admin">
        select * from admin where account=#{acc} and password=#{pwd}
         </select>

也可以是对象传参

 /*对象传参数*/
    Admin login1(Admin admin);

 相对于的映射文件中的配置

<select id="login1" parameterType="admin" resultType="Admin">
        select * from admin where account=#{account} and password=#{password}
         </select>

 这里account和password是Admin中的属性

六、mybatis使用示例(新增、修改、删除)

数据库事务:是数据库的一种管理机制,是对一次连接数据库过程的管理操作,保证一次操作中,执行的多条sql,要么都成功执行,要么都不执行。

因此,在Java中执行新增,修改,删除操作时都要进行手动提交事务(

sqlSession.commit();//提交数据库事务,当我们的程序代码块没有任何问题时,在向数据库提交事务操作,数据库才会执行sql,出现异常不提交事务

新增示例:(单表操作)

1、定义新增接口

package com.ffyc.mybatispro.dao;
import com.ffyc.mybatispro.model.Admin;
import java.util.List;
public interface AdminDao {
    /*对象传参数*/
    void insertAdmin(Admin admin);
}

2、在sql映射文件中写sql语句

    <insert id="insertAdmin" parameterType="Admin" useGeneratedKeys="true" keyProperty="id" keyColumn="id">
        insert into admin(account,password,gender) values(#{account},#{password},#{gender})
    </insert>
useGeneratedKeys="true":返回自增主键
keyProperty="id":第一接收属性
 keyColumn="id":数据库列

单表查询,返回的结果mybatis可以自动将一条记录映射到Java对象中
要求:列名和对象属性一致

3、单元测试(程序员使用的测试方法,以方法为单位)

所以需要引入junit依赖

          <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>provided</scope>
          </dependency>
 @Test
    public void insert(){
  //1.mybatis读取配置文件
      Reader reader= Resources.getResourceAsReader("mybatis.xml");
        //2.创建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);
        //SqlSessionFactory对象也只需要创建一次,创建后不想需要销毁
        //3.创建 SqlSession
        SqlSession sqlSession=sqlSessionFactory.openSession();//打开与数据库的会话
        System.out.println("新增");
        Admin admin=new Admin();
        admin.setAccount("aaa");
        admin.setPassword("123");
        admin.setGender("男");
        AdminDao adminDao=sqlSession.getMapper(AdminDao.class);
        adminDao.insertAdmin(admin);//保存数据后,需要立刻拿到这条数据在数据库中的主键
        System.out.println(admin.getId());

        sqlSession.commit();//手动提交数据库事务管理
        sqlSession.close();
       
    }

 2、修改示例

1、定义修改接口

package com.ffyc.mybatispro.dao;

import com.ffyc.mybatispro.model.Admin;
import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface AdminDao {

    /*对象传参数*/
    void updateAdmin(Admin admin);

}

2、在sql映射文件中写sql语句

   <update id="updateAdmin" parameterType="Admin">
        update admin set account=#{account},password=#{password} where id=#{id}
    </update>

3、单元测试

    public void update(){

        System.out.println("修改");
      Reader reader= Resources.getResourceAsReader("mybatis.xml");
        //2.创建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);
        //SqlSessionFactory对象也只需要创建一次,创建后不想需要销毁
        //3.创建 SqlSession
        SqlSession sqlSession=sqlSessionFactory.openSession();//打开与数据库的会话
        
        AdminDao adminDao=sqlSession.getMapper(AdminDao.class);
        Admin admin=new Admin();
        admin.setId(3);
        admin.setAccount("ccc");
        admin.setPassword("666");
        admin.setGender("男");
        adminDao.updateAdmin(admin);
        sqlSession.commit();
        sqlSession.close();
    }

执行结果

 

删除示例

1、定义删除接口

package com.ffyc.mybatispro.dao;

import com.ffyc.mybatispro.model.Admin;
import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface AdminDao {

    /*一个值传参数*/

    void deleteAdmin(int id);
   
 

}

2、在sql映射文件中写sql语句

    <delete id="deleteAdmin" parameterType="int">
        delete from admin where id = #{id}
    </delete>

3、单元测试

   @Test
    public void delete(){
        System.out.println("删除");
       PUblic static void main(String[] args) throws IOException {
        //1.mybatis读取配置文件
      Reader reader= Resources.getResourceAsReader("mybatis.xml");
        //2.创建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);
        //SqlSessionFactory对象也只需要创建一次,创建后不想需要销毁
        //3.创建 SqlSession
        SqlSession sqlSession=sqlSessionFactory.openSession();//打开与数据库的会话
        
        AdminDao adminDao=sqlSession.getMapper(AdminDao.class);
        adminDao.deleteAdmin(3);
        sqlSession.commit();
        sqlSession.close();
    }

执行结果

删除了id=3的一行

七、🐦🐦🐦MybatisX:

 mybatis的一个小插件可以快速帮助我们使用sql映射文件和接口

点击旁边的小鸟会快速的转换到相应的sql映射文件或者时接口

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

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

相关文章

用Python解决优化问题_整数规划模板

整数规划的基本概念 整数规划是一种数学优化方法&#xff0c;它是线性规划的一个扩展。在整数规划中&#xff0c;决策变量被限制为整数&#xff0c;而不是连续的值。这种类型的规划在许多实际应用中非常重要&#xff0c;例如资源分配、生产计划、物流配送等。整数规划可以分为…

R7RS标准之重要特性及用法实例(三十九)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 新书发布&#xff1a;《Android系统多媒体进阶实战》&#x1f680; 优质专栏&#xff1a; Audio工程师进阶系列…

【数据库】深入浅出MySQL SQL优化:原因、定位、分析与索引失效

这是一张AI生成关于MySQL SQL优化的插图。图中展示了一个计算机屏幕&#xff0c;上面可以看到MySQL数据库模式。屏幕周围有代表优化的视觉隐喻&#xff0c;如齿轮、闪电和流线型形状。屏幕上的模式用色彩丰富的注释标出了改进区域&#xff0c;如索引和查询调整。整体风格现代且…

【源码+文档+调试讲解】数据结构课程网络学习平台

摘要 本文介绍了数据结构课程网络学习平台的开发全过程。通过分析企业对于数据结构课程网络学习平台的需求&#xff0c;创建了一个计算机管理数据结构课程网络学习平台的方案。文章介绍了数据结构课程网络学习平台的系统分析部分&#xff0c;包括可行性分析等&#xff0c;系统设…

Python处理JSON

Python处理JSON ####概念 序列化&#xff08;Serialization&#xff09;&#xff1a;将对象的状态信息转换为可以存储或可以通过网络传输的过程&#xff0c;传输的格式可以是JSON、XML等。反序列化就是从存储区域&#xff08;JSON&#xff0c;XML&#xff09;读取反序列化对象…

优化学习管理:Moodle和ONLYOFFICE文档编辑器的完美结合

目录 前言 一、什么是 Moodle 1、简单快速插入表单字段 3、免费表单模板库 4、开启无缝协作 三、在Moodle中集成ONLYOFFICE文档 四、在Moodle安装使用ONLYOFFICE 1、下载安装 2、配置服务器 3、在Moodle中使用ONLYOFFICE 文档活动 五、未来展望 写在最后 前言 在当今教育科技飞…

前端如何在30秒内实现吸管拾色器?

⭐前言 大家好&#xff0c;我是yma16&#xff0c;本文分享 前端react——实现浏览器页面的吸管拾色器功能。 背景&#xff1a; 在chrome web端快速实现一个页面的取色器功能&#xff0c; 分为两个场景 固定区域小范围取色当前页面取色 node系列往期文章 node_windows环境变量…

Vue3-win7搭建vue3环境

Vue3-win7搭建vue3环境 官方要求的信息是是node.js 18.03以上。而我的环境&#xff1a;win7 x64&#xff0c; vscode 1.34。 参考网址&#xff1a; 0、基本的安装 https://blog.csdn.net/m0_49139268/article/details/126159171 a、这里有各种安装包的下载路径&#xff08;镜…

手撕C++类和对象(中)

1.类的默认成员函数 默认成员函数就是⽤⼾没有显式实现&#xff0c;编译器会⾃动⽣成的成员函数称为默认成员函数。⼀个类&#xff0c;我 们不写的情况下编译器会默认⽣成以下6个默认成员函数&#xff0c;需要注意的是这6个中最重要的是前4个&#xff0c;最 后两个取地址重载不…

[数据集][目标检测]管道漏水泄漏破损检测数据集VOC+YOLO格式2614张4类

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;2614 标注数量(xml文件个数)&#xff1a;2614 标注数量(txt文件个数)&#xff1a;2614 标注…

10天速通Tkinter库——实践项目《植物杂交实验室》

一不小心就拖更了五天&#xff0c;私密马赛。但你们知道这五天我都是怎么过的吗&#xff0c;我起早贪黑&#xff08;起不来一点&#xff09;&#xff0c;每天勤勤恳恳撸代码&#xff0c;做设计&#xff08;谁家好人用ppt做设计哇&#xff09;&#xff0c;只为完成《植物杂交实验…

Vue 和 Element Plus 弹框组件详解:从基本实现到异步数据加载与自定义内容(实战)

目录 前言1. 基本知识2. 模版3. 实战 前言 主要是通过一个按钮触发一个按钮框&#xff0c;多种方式的逻辑&#xff0c;多种场景 原先通过实战总结&#xff0c;基本的知识推荐阅读&#xff1a; 详细分析Element Plus中的ElMessageBox弹窗用法&#xff08;附Demo及模版&#x…

【STM32单片机_(HAL库)】3-4-1【中断EXTI】【智能排队控制系统】LCD1602显示字符串

1.硬件 STM32单片机最小系统LCD1602显示模块 2.软件 驱动文件添加GPIO常用函数main.c程序 #include "sys.h" #include "delay.h" #include "led.h" #include "lcd1602.h"int main(void) {HAL_Init(); /* …

摄像头实时检查程序,插入设备,自动显示画面,支持多个摄像头,支持拍照,照片放大缩小

支持的特性 插入摄像头设备后&#xff0c;无需手动选择&#xff0c;自动显示摄像头画面&#xff0c;需要预先授权支持多个摄像头切换显示多个摄像头时支持 默认显示特定名称的摄像头支持拍照支持照片放大&#xff0c;缩小 显示效果 完整代码 <!DOCTYPE html> <html…

使用 AMD GPUs 进行基于 Transformers 的时间序列预测

Using AMD GPUs for Enhanced Time Series Forecasting with Transformers — ROCm Blogs 时间序列预测&#xff08;TSF&#xff09;是信号处理、数据科学和机器学习&#xff08;ML&#xff09;等领域的关键概念。TSF 通过分析系统的过去时间模式来预测其未来行为&#xff0c;利…

私域流量升级下的新机遇——“开源 AI 智能名片S2B2C 商城小程序”与新兴技术的融合

摘要&#xff1a;本文深入探讨了随着私域流量应用的进一步升级&#xff0c;智能对话式营销持续火爆的同时&#xff0c;CEM&#xff08;客户体验管理&#xff09;、MA&#xff08;营销自动化&#xff09;、CDP&#xff08;客户数据平台&#xff09;及 DAM&#xff08;数据资产管…

《黑神话:悟空》之光线追踪技术

8月20日&#xff0c;国产单机游戏《黑神话&#xff1a;悟空》终于上市&#xff0c;并以实力演绎了爆款游戏的“盛况空前”。 这款游戏的成功&#xff0c;不仅源自对经典文学《西游记》的深刻解读与创新演绎&#xff0c;更在于其背后强大的科技力量支撑。 空间计算功不可没 土…

游戏服务器架构:基于匿名函数的高性能异步定时器系统

作者&#xff1a;码客&#xff08;ygluu 卢益贵&#xff09; 关键词&#xff1a;游戏服务器架构、匿名函数、高性能、异步定时器。 一、前言 本文主要介绍适用于MMO/RPG游戏服务端的、基于匿名函数做定时器回调函数的、高性能异步触发的定时器系统的设计方案&#xff0c;以解决…

《深入浅出WPF》读书笔记.7依赖属性和附加属性

《深入浅出WPF》读书笔记.7依赖属性和附加属性 背景 总结一下wpf依赖属性和附加属性的底层逻辑&#xff0c;方便更好的理解使用。 属性 CLR属性由来 static属性和非static属性的区别 static属性:对类有意义&#xff0c;内存只有一个实例&#xff1b; 非static属性:对类实…

WPF—LiveCharts图表

LiveCharts图表 LiveCharts是一个简单灵活、交互式以及功能强大的跨平台图表库&#xff0c;支持wpf、winform...应用程序。 快速入门 安装 在应用程序中右键引用​&#xff0c;点击管理NuGet程序包​&#xff0c;选择浏览​&#xff0c;搜索LiveChartsCore.SkiaSharpView.W…