mybatis的增删改查运用

news2024/12/28 18:14:49

目录

一、总览图

二、运用 


一、总览图

代码总览图 

 数据库总览图

 

二、运用 

数据库的一张表对应一个封装类,一个mapper接口,一个mapper.xml文件, 一个实现类。表中的增删改查都在里面编写

但是配置xml文件整个数据库只要一个就好了

1.pom.xml文件根据创建的maven或者spring项目去配置

2.mybatis统一配置xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "https://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.cj.jdbc.Driver"/><!--改:数据库的固定连接,老版本不用cj-->
                <property name="url" value="jdbc:mysql://localhost:3306/mishop?useSSL=false&amp;serverTimezone=UTC"/><!--mishop改:数据库的要连接的库-->
                <property name="username" value="root"/><!--改:数据库的账号-->
                <property name="password" value="root"/><!--改:数据库的密码-->
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <!--加载映射文件-->
        <mapper resource="com/project/Mapper/AdminMapper.xml"/><!--改:把映射文件的源根路径复制到这里-->
    </mappers>
</configuration>

 

3.pojo里面的封装类(属性对应数据库表中的属性)

ps:里面要含有set、get方法,有无参构造方法、toString

package com.project.pojo;


public class Admin {
    private Integer adminId;
    private String adminName;
    private String adminPwd;
    private Integer adminDisable;

    public Integer getAdminId() {
        return adminId;
    }

    public void setAdminId(Integer adminId) {
        this.adminId = adminId;
    }

    public String getAdminName() {
        return adminName;
    }

    public void setAdminName(String adminName) {
        this.adminName = adminName;
    }

    public String getAdminPwd() {
        return adminPwd;
    }

    public void setAdminPwd(String adminPwd) {
        this.adminPwd = adminPwd;
    }

    public Integer getAdminDisable() {
        return adminDisable;
    }

    public void setAdminDisable(Integer adminDisable) {
        this.adminDisable = adminDisable;
    }

    public Admin(Integer adminId, String adminName, String adminPwd, Integer adminDisable) {
        this.adminId = adminId;
        this.adminName = adminName;
        this.adminPwd = adminPwd;
        this.adminDisable = adminDisable;
    }

    public Admin() {
    }

    @Override
    public String toString() {
        return "Admin{" +
                "adminId=" + adminId +
                ", adminName='" + adminName + '\'' +
                ", adminPwd='" + adminPwd + '\'' +
                ", adminDisable=" + adminDisable +
                '}';
    }
}

4.SQL语句接口映射文件(小蓝鸟

ps:红蓝小鸟插件(作用:方便好看)

package com.project.Mapper;

import com.project.pojo.Admin;

import java.util.List;
public interface AdminMapper {
    //增
    // void (封装类 封装类小写)
    //括号要用封装类是因为表里面那行数据都要进行增加
    void add (Admin admin);

    //改
    // void 自定义名称 (封装类 封装类小写);
    //括号要用封装类是因为表里面那行数据都要进行增加
    void updateId(Admin admin);

    //查全部
    // list <pojo封装类> 自定义全部查询();
    //因为是查询全部,所以括号里面不用加任何参数
    List<Admin> selectAll();

    //查单个
    //list <pojo封装类> 自定义全部查询(自定义参数根据id查询);
    List<Admin> selectId(int id);


    //删
    // void 自定义名称 (自定义参数为要根据id进行删除);
    void deleteId(int id);
}

5.编写SQL语句映射的xml文件(小红鸟

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">

<!--sql映射查询方法-->

<!--namespace=对应接口的全部路径-->
<mapper namespace="com.project.Mapper.AdminMapper">
        <!--新增的SQL语句    -->
        <!--第一行:insert新增标签 id="接口定义的名字"  parameterType="封装类的全限名"     -->
        <!--第二行:SQL语句-自增id用null,其他的用#{封装类的属性名} ,....   -->
    <insert id="add" parameterType="com.project.pojo.Admin">
        insert into admin values (null,#{adminName},#{adminPwd},#{adminDisable})
    </insert>

        <!--删除的SQL语句    -->
        <!-- 第一行:delete删除标签 id="接口定义的名字"  parameterType="封装类的全限名"   -->
        <!--第二行:SQL语句-根据id(封装的属性)进行删除    -->
    <delete id="deleteId" parameterType="com.project.pojo.Admin">
        delete from admin where adminId=#{adminId}
    </delete>

        <!--修改的SQL语句    -->
        <!--第一行:update修改标签  id="接口定义的名字"  parameterType="封装类的全限名"   -->
        <!-- 第二行:SQL语句-因为要修改的是那行的全部数据,所以封装的属性都要一一对应写出来    -->
    <update id="updateId" parameterType="com.project.pojo.Admin">
        update admin set adminName=#{adminName},adminPwd=#{adminPwd},adminDisable=#{adminDisable} where adminId=#{adminId}
    </update>

    <!--查询全部的SQL语句    -->
    <!-- 第一行:select查询标签  resultType="封装类的权限定名"  -->
    <select id="selectAll" resultType="com.project.pojo.Admin">
        select * from admin
    </select>
    <!-- 查询单个的SQL语句  如上 -->
    <select id="selectId" resultType="com.project.pojo.Admin">
        select * from admin where AdminId=#{adminId}
    </select>

</mapper>

6.实现类(要运行哪个就直接从注释里面提取出来就好)

package com.project.pojo;

import com.project.Mapper.AdminMapper;
import lombok.extern.slf4j.Slf4j;
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 java.io.IOException;
import java.io.InputStream;


public class AdminImpl {
    public static void main(String[] args) throws IOException {

        //1.加载mybatis连接文件(核心配置文件)
        String resource = "mybatis-config.xml";//这是连接数据库的
        InputStream inputStream = Resources.getResourceAsStream(resource);//固定写法
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);//固定写法

        //2.获取sqlSessionFactory对象--固定的写法
        SqlSession sqlSession = sqlSessionFactory.openSession();

        //3.执行sql语句
        AdminMapper adminMapper = sqlSession.getMapper(AdminMapper.class);


        //以下这些用哪个执行哪个

/*         // 添加的方法
        Admin admin = new Admin();
        admin.setAdminName("wangwu");
        admin.setAdminPwd("8888");
        admin.setAdminDisable(54);
        //Mapper接口里面的添加方法
        adminMapper.add(admin);
        */


/*        Mapper接口里面的删除方法
        adminMapper.deleteId(14);
        */


/*      修改的方法
        Admin admin = new Admin();
        admin.setAdminId(7);
        admin.setAdminName("王五");
        admin.setAdminPwd("123456");
        admin.setAdminDisable(5555);
        //Mapper接口里面的修改方法
        adminMapper.updateId(admin);
        */


/*      查询单个的方法,Mapper接口里面的查询方法
        List<Admin> selectId = adminMapper.selectId(5);
        System.out.println(selectId);
        */

/*        //查询全部的方法
        List<Admin> selectAll = adminMapper.selectAll();
        System.out.println(selectAll);*/
        
        //提交
        sqlSession.commit();

        //6.释放资源
        sqlSession.close();
    }

}

 总结:路是一步一步慢慢走的,饭是一口一口吃的,每天进步,打好基础就好

有什么问题都可以评论区留言,看见都会回复的

如果你觉得本篇文章对你有所帮助的,多多支持吧!!!

点赞收藏评论,抱拳了!

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

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

相关文章

路由器与交换机的区别(基础知识)

文章目录交换机路由器路由器和交换机的区别&#xff08;1&#xff09;工作层次不同&#xff08;2&#xff09;数据转发所依据的对象不同&#xff08;3&#xff09;传统的交换机只能分割冲突域&#xff0c;不能分割广播域&#xff1b;而路由器可以分割广播域&#xff08;4&#…

软件大战升级,通用汽车与Qt达成合作,增强车内体验

从智能汽车产业现状来看&#xff0c;围绕软件而展开的争夺战已经打响。 英伟达首席执行官黄仁勋曾预测&#xff0c;未来四年内新车以成本价销售将不再是“天方夜谭”&#xff0c;因为利润将来自软件。 比如&#xff0c;英伟达与奔驰的合作&#xff0c;就将首次采用功能订阅的…

docker安装及命令使用

目录 1. Docker版本介绍 2. 创建Docker存储库 3. 安装docker软件包 4. Docker命令补全 6.Docker命令介绍 7. Docker镜像管理 7.1 列出本地镜像 7.2 搜索镜像 7.3 下载镜像 7.4 查看镜像 7.5 删除镜像 7.6 导出镜像 7.7 导入镜像 7.8 镜像改名 8. 容器管理 8.1 容…

再学C语言41:变长数组(VLA)

处理二维数组的函数&#xff1a;数组的行可以在函数调用时传递&#xff0c;但是数组的列只能被预置在函数内部 示例代码&#xff1a; #define COLS 4 int sum(int arr[][COLS], int rows) {int r;int c;int temp 0;for(r 0; r < rows; r){for(c 0; c < COLS; c){tem…

每个Android开发都应需知的性能指标~

无论你是发布一个新的 Android 应用&#xff0c;还是希望提高现有应用的性能&#xff0c;你都可以使用 Android 应用性能指标来帮助你。 在这篇文章中&#xff0c;我将解释什么是 Android 应用性能指标&#xff0c;并列出8个需要考虑跟踪的维度和建议的基线。 什么是 Android…

【LEAP模型】能源环境发展、碳排放建模

本次内容突出与实例结合&#xff0c;紧密结合国家能源统计制度及《省级温室气体排放编制指南》&#xff0c;深入浅出地介绍针对不同级别研究对象时如何根据数据结构、可获取性、研究目的&#xff0c;构建合适的能源生产、转换、消费、温室气体排放&#xff08;以碳排放为主&…

【NLP相关】深度学习领域不同编程IDE对比

❤️觉得内容不错的话&#xff0c;欢迎点赞收藏加关注&#x1f60a;&#x1f60a;&#x1f60a;&#xff0c;后续会继续输入更多优质内容❤️&#x1f449;有问题欢迎大家加关注私戳或者评论&#xff08;包括但不限于NLP算法相关&#xff0c;linux学习相关&#xff0c;读研读博…

死锁相关介绍【内含哲学家就餐问题】

死锁 死锁是这样一种情形&#xff1a;多个线程同时被阻塞&#xff0c;它们中的一个或者全部都在等待某个资源被释放。由于线程被无限期地阻塞&#xff0c;因此程序不可能正常终止。 场景1&#xff1a;一个线程&#xff0c;一把锁 一个线程&#xff0c;一把锁&#xff0c;线程…

【Linux】孤儿进程

在Linux中&#xff0c;如果子进程运行时&#xff0c;父进程因为某些原因先行终止&#xff0c;就称该子进程为孤儿进程。 我们编写如下代码&#xff1a; 子进程一直在运行&#xff0c;父进程运行一段时间后自动终止。运行该程序观察现象&#xff1a; 最开始时&#xff0c;子进程…

Unity 命令行发Android包

unity.exe 只允许存在一个 如果开了ide 或者之前的没关掉 就不能运行了 C: cd C:\Program Files\Unity\Editor\2021.3.6f1c1\Editor\ Unity.exe ^ -quit ^ -batchmode ^ -projectPath E:\puerts\UnityJenkins ^ -executeMethod Main.BuildC#代码放到任意Editor目录里 using S…

【linux】进程信号——信号的产生

进程信号一、信号概念1.1 信号理解二、产生信号2.1 通过键盘产生信号2.2 捕捉信号自定义signal2.3 系统调用接口产生信号2.3.1 向任意进程发送任意信号kill2.3.2 给自己发送任意信号raise2.3.3 给自己发送指定信号abort2.3.4 理解2.4 硬件异常产生信号2.4.1 除0异常2.4.2 野指针…

ACM-大一训练第三周(Floyd算法+并查集算法专题训练)

&#x1f680;write in front&#x1f680; &#x1f4dd;个人主页&#xff1a;认真写博客的夏目浅石.CSDN &#x1f381;欢迎各位→点赞&#x1f44d; 收藏⭐️ 留言&#x1f4dd;​ &#x1f4e3;系列专栏&#xff1a;ACM周训练题目合集.CSDN &#x1f4ac;总结&#xff1a…

五、Bean的作用域

1 singleton 默认情况下&#xff0c;Spring的IoC容器创建的Bean对象是单例的。测试&#xff1a; package com.power.spring6.bean;public class SpringBean {public SpringBean() {System.out.println("无参数构造方法执行了");} }<?xml version"1.0"…

Ubuntu中使用Synaptic进行包管理

Synaptic概况 Synaptic 是一个轻量级的 apt 软件包管理器系统的 GUI 前端&#xff0c;所有你可以在终端中使用 apt-get 命令来做的事&#xff0c;都可以通过 Synaptic 来实现。优势 图形化安装界面&#xff0c;同时可以安装配置相关依赖&#xff0c;避免由于依赖问题导致的各类…

【c++】2023杭州月薪个税计算(chatGPT帮忙加注释)

参考信息 杭州市的个人所得税起征点是每月5000元。 个人所得税税率标准&#xff1a; 1、工资范围在1-5000元之间的&#xff0c;包括5000元&#xff0c;适用个人所得税税率为0%; 2、工资范围在5000-8000元之间的&#xff0c;包括8000元&#xff0c;适用个人所得税税率为3%; 3、工…

SpringBoot3.0 + SpringSecurity6.0+JWT

JWT_SpringSecurity SpringBoot3.0 SpringSecurity6.0JWT Spring Security 是 Spring 家族中的一个安全管理框架。 一般Web应用的需要进行认证和授权。 认证&#xff1a;验证当前访问系统的是不是本系统的用户&#xff0c;并且要确认具体是哪个用户 授权&#xff1a;经过认…

「C/C++」 标准文件操作大全

一、设备文件&#xff08;运行程序时会默认打开这三个设备文件&#xff09; stdin&#xff1a;标准输入&#xff0c;默认为当前终端&#xff08;键盘&#xff09;&#xff0c;我们使用的scanf、getchar函数默认从此终端获得数据。stdout&#xff1a; 标准输出&#xff0c;默认…

当你问ChatGPT一些奇奇怪怪的问题

ChatGPT热度好像已经没那么高了&#xff0c;貌似也蹭不到什么流量了&#xff0c;不过嘛&#xff0c;玩了一下好玩的还是得记录一下。每个问题用标题给出&#xff0c;就可以当目录了。同时附上截图&#xff0c;想直接看图的伙伴可以直接看图。回答以绿色背景的形式给出。 觉得有…

坚如磐石:TiDB 基于时间点的恢复(PiTR)特性优化之路丨6.5 新特性解析

本文介绍了 TiDB 数据库的基于时间点的恢复&#xff08;PiTR&#xff09;特性&#xff0c;该特性允许用户将数据库恢复到特定时间点&#xff0c;从而避免丢失重要数据。文章首先介绍了 PiTR 技术的基本概念和工作原理&#xff0c;接着探讨了 TiDB 对 PiTR 的优化&#xff0c;包…

Java多线程(二)——同步

这一节主要是继上次提到的线程同步三大方法&#xff1a;同步代码块、同步方法、Lock锁。同步代码块&#xff0c;把出现线程安全问题的核心代码给上锁。还是继上次的例子&#xff0c;对代码块加上synchronized ("getMoney") {}之后就不会出现线程安全问题了&#xff1…