MyBatis中文网:https://mybatis.net.cn/

1 什么是 MyBatis

MyBatis一款优秀的持久框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数获取结果集的工作
MyBatis 可以通过简单的 XML 或注解配置映射原始类型接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录

持久层:指的是就是数据访问层(dao),是用来操作数据库的。
在这里插入图片描述

2 Mybatis基础操作

根据主键 ID 删除数据

//使用#{key}方式获取方法中的参数
@Delete("delete from emp where id = #{id}")
public void delete(Integer id);

新增(可主键返回

@Options(useGeneratedKeys = true,keyProperty = "id")	// 会自动生成主键值,赋值emp对象id属性(可省略
@Insert("insert into emp(username, name, gender, image, job, entrydate, dept_id, create_time, update_time) values (#{username}, #{name}, #{gender}, #{image}, #{job}, #{entrydate}, #{deptId}, #{createTime}, #{updateTime})")
public void insert(Emp emp);

更新

@Update("update emp set username=#{username}, name=#{name}, gender=#{gender}, image=#{image}, job=#{job}, entrydate=#{entrydate}, dept_id=#{deptId}, update_time=#{updateTime} where id=#{id}")
public void update(Emp emp);

查询

@Select("select id, username, password, name, gender, image, job, entrydate, dept_id, create_time, update_time from emp where id=#{id}")
public Emp getById(Integer id);

3 Mybatis的XML配置文件

Mybatis的开发有两种方式,分别是注解和XML

3.1 XML配置文件规范

在Mybatis中使用XML映射文件方式开发需要符合一定的规范
  1. XML映射文件名称与Mapper接口名称一致,并且将XML映射文件和Mapper接口放置相同包下(同包同名)
  2. XML映射文件的namespace属性为Mapper接口全限定名一致
  3. XML映射文件中sql语句的id与Mapper接口中的方法名一致,并保持返回类型一致。

XML配置文件

<?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.wuyh.mapper.EmpMapper">
    <select id="list2" resultType="com.wuyh.pojo.Emp">
        select * from mybatis.emp where name like concat('%', #{name}, '%') and gender = #{gender} and entrydate between #{begin} and #{end} order by update_time desc
    </select>
</mapper>

使用Mybatis的注解,主要是来完成一些简单增删改查功能。如果需要实现复杂的SQL功能建议使用XML来配置映射语句

4 Mybatis动态SQL

动态SQL:SQL语句会随着用户输入外部条件的变化而变化。

<if>用于判断条件是否成立。使用test属性进行条件判断,如果条件true,则拼接SQL。

<if test="条件表达式">拼接sql语句
</if>

<where>where元素只会在子元素内容的情况下才插入where子句,而且会自动去除子句开头的AND或OR

<set>动态地在行首插入 SET 关键字,并会删掉额外逗号。(用在update语句中)

<foreach>:为批量处理数据提供循环遍历操作

<foreach collection="集合名称" item="集合遍历出来的元素/项" separator="一次遍历使用分隔" open="遍历开始前拼接片段" close="遍历结束拼接片段">
</foreach>

<sql>定义可重用的SQL片段
<include>:通过属性refid,指定包含的SQL片段

通过<sql>标签封装一个SQL片段然后再通过<include>标签进行引用。两者配合使用
作用:对重复的SQL代码片段进行封装,减少冗余

原文地址:https://blog.csdn.net/qq_1532145264/article/details/134685405

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_43614.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注