MyBatis的xml实现

1.下载插件MyBatisX

2.添加依赖

java 复制代码
<!--Mybatis 依赖包-->
		<dependency>
			<groupId>org.mybatis.spring.boot</groupId>
			<artifactId>mybatis-spring-boot-starter</artifactId>
			<version>2.3.1</version>
		</dependency>
		<!--mysql驱动包-->
		<dependency>
			<groupId>com.mysql</groupId>
			<artifactId>mysql-connector-j</artifactId>
			<scope>runtime</scope>
		</dependency>

3. 配置yml文件

java 复制代码
mybatis:
 mapper-locations: classpath:mapper/*Mapper.xml
 configuration: # 配置打印 MyBatis 执行的 SQL
  log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  map-underscore-to-camel-case: true  #自动驼峰转换
# 配置打印 MyBatis 执行的 SQL

注意

mapper为创建的目录名,自己设置,还有Mapper也可以自己设,但是一定要保持一致

4.创建文件

①创建Mapper文件,首先在java目录下创建mapper目录,在mapper目录下常见UserInfoXNMLMapper文件,其次在resource目录下创建mapper目录,在maaper目录下创建同名的UserInfoXNMLMapper(必须一样),如果不一致,会出现spring找不到的情况,项目无法启动

在UserInfoXNMLMapper文件中加入方法

java 复制代码
package com.example.demo.mapper;

import com.example.demo.model.UserInfo;
import org.apache.ibatis.annotations.Mapper;

import java.util.List;
@Mapper
public interface UserInfoXMLMapper {
    List<UserInfo> selectAll();
}

注意

加注解@mapper,不添加会报错

在xml文件添加代码

java 复制代码
<?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.example.demo.mapper.UserInfoXMLMapper">
    <select id="selectAll" resultType="com.example.demo.model.UserInfo">
        select* from userinfo
    </select>
</mapper>

注意

1.mapper标签中的namespace内容是java目录下的UserInfoXNMLMapper文件路径

2.select标签为自己编写的查询语句 ,其中id是UserInfoXNMLMapper中的方法名必须一模一样,resultType为返回数据的类型

3.只有在select才会需要resultType

5.xml文件实现增删查改

①增

方法声明在UserInfoXNMLMapper文件中

java 复制代码
Integer insert(UserInfo userInfo);

在UserInfoXNMLMapper.xml文件中实现,用insert标签

java 复制代码
<insert id="insert" useGeneratedKeys="true" keyProperty="id">
        insert into userinfo (username, password, age, gender, phone)
        values(#{username},#{password},#{age},#{gender},#{phone})
    </insert>

注意

1.方法名和id一定要一样

2.useGeneratedKeys="true" keyProperty="id"自主获取id

3.如果出现重命名则需要对象应用 如userInfo.username

②删

方法声明在UserInfoXNMLMapper文件中,根据id删除

java 复制代码
Integer delete (int id);

在UserInfoXNMLMapper.xml文件中实现,用delete标签

java 复制代码
 <delete id="delete">
        delete from userinfo where id=#{id}
    </delete>

③改

方法声明在UserInfoXNMLMapper文件中,根据id

java 复制代码
Integer update(int gender,int id);

在UserInfoXNMLMapper.xml文件中实现,用update标签

java 复制代码
<update id="update">
        update userinfo set gender=#{gender} where id=#{id};
    </update>
相关推荐
纪莫21 分钟前
A公司一面:类加载的过程是怎么样的? 双亲委派的优点和缺点? 产生fullGC的情况有哪些? spring的动态代理有哪些?区别是什么? 如何排查CPU使用率过高?
java·java面试⑧股
JavaGuide1 小时前
JDK 25(长期支持版) 发布,新特性解读!
java·后端
用户3721574261351 小时前
Java 轻松批量替换 Word 文档文字内容
java
白鲸开源1 小时前
教你数分钟内创建并运行一个 DolphinScheduler Workflow!
java
Java中文社群2 小时前
有点意思!Java8后最有用新特性排行榜!
java·后端·面试
代码匠心2 小时前
从零开始学Flink:数据源
java·大数据·后端·flink
间彧2 小时前
Spring Boot项目中如何自定义线程池
java
间彧2 小时前
Java线程池详解与实战指南
java
用户298698530143 小时前
Java 使用 Spire.PDF 将PDF文档转换为Word格式
java·后端
渣哥3 小时前
ConcurrentHashMap 1.7 vs 1.8:分段锁到 CAS+红黑树的演进与性能差异
java