MyBatis 的XML实现方法

MyBatis 的XML实现方法

MyBatis 的XML实现方法

前情提示

关于mybatis的重要准备工作,请看MyBatis 的注解实现方法

创建mapper接口

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();
    List<UserInfo> selectAll2();
    Integer insert(UserInfo userInfo);
    Integer DeleteByID(Integer id);
    Integer Update(UserInfo userInfo);
    List<UserInfo> selectAllBYOrder(String sort);
}

添加配置

java 复制代码
mybatis:
  configuration:
    map-underscore-to-camel-case: true
  mapper-locations: classpath:mapper/**Mapper.xml

mapper-locations: classpath:mapper/**Mapper.xml中的mapper表示resources下的包,Mapper.xml表示mapper下的以Mapper.xml结尾的文件

创建xml文件

resources下创建mapper包,在mapper下创建以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">
</mapper>

图中需要填写的是之前创建的mapper接口的全限定类名加方法名

操作数据库

xml中的标签对应前面mapper接口中定义的方法

insert标签

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

delete标签

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

select标签

java 复制代码
    <select id="selectAll" resultType="com.example.demo.model.UserInfo">
        select * from userinfo
    </select>

这里的resultType也是全限定类名

这里也存在注解中存在的问题,数据格式不同

使用下面的标签即可解决

resultMap标签

java 复制代码
    <resultMap id="xmlBaseMap" type="com.example.demo.model.UserInfo">
        <id column="id" property="id"></id>
        <result column="delete_flag" property="deleteFlag"></result>
        <result column="create_time" property="createTime"></result>
        <result column="update_time" property="updateTime"></result>
    </resultMap>
    <select id="selectAll2"  resultMap="xmlBaseMap">
        select * from userinfo
    </select>

update标签

java 复制代码
    <update id="Update">
        update userinfo set age=#{age} where username=#{username}
    </update>

sql标签,include标签

将一些重复率过高的代码通过sql标签包裹起来

使用时通过include来调用

java 复制代码
    <sql id="baseSelect">
        select * from userinfo
    </sql>
    <select id="selectAllBYOrder" resultMap="xmlBaseMap">
        <include refid="baseSelect"></include>
        order by id ${sort}
    </select>
相关推荐
givemeacar3 小时前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis
小江的记录本6 小时前
【Bean】JavaBean(原生规范)/ Spring Bean 【重点】/ 企业级Bean(EJB/Jakarta Bean)
java·数据库·spring boot·后端·spring·spring cloud·mybatis
bearpping7 小时前
Spring Boot 整合 MyBatis 与 PostgreSQL 实战指南
spring boot·postgresql·mybatis
不吃香菜学java8 小时前
苍穹外卖-菜品分页查询
数据库·spring boot·tomcat·log4j·maven·mybatis
java修仙传8 小时前
数据库和缓存的一致性如何保证?
redis·mysql·mybatis
不吃香菜学java9 小时前
苍穹外卖-新增菜品代码开发
spring boot·spring·servlet·log4j·maven·mybatis
qq_3340602110 小时前
spring_springmvc_mybatis权限控制+boostrap实现UI
java·spring·mybatis
Predestination王瀞潞10 小时前
6.3.1 软件->W3C XPath 1.0 标准(W3C Recommendation):XPath(XML Path Language)查询语言
xml·数据库·oracle
深蓝轨迹11 小时前
黑马点评-day02-缓存笔记
redis·笔记·缓存·mybatis
小江的记录本11 小时前
【Spring Boot】Spring Boot 全体系知识结构化拆解(附 Spring Boot 高频面试八股文精简版)
java·spring boot·后端·spring·面试·tomcat·mybatis