文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么在Mybatis中搭建动态SQL环境

2023-06-14 23:15

关注

今天就跟大家聊聊有关怎么在Mybatis中搭建动态SQL环境,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

1. Mybatis–动态SQL

动态 SQL 是 MyBatis 的强大特性之一。如果你使用过 JDBC 或其它类似的框架,你应该能理解根据不同条件拼接 SQL 语句有多痛苦,例如拼接时要确保不能忘记添加必要的空格,还要注意去掉列表最后一个列名的逗号。利用动态 SQL,可以彻底摆脱这种痛苦。

在 MyBatis 之前的版本中,需要花时间了解大量的元素。
借助功能强大的基于 OGNL 的表达式,MyBatis 3 替换了之前的大部分元素,
大大精简了元素种类,现在要学习的元素种类比原来的一半还要少。

if
choose (when, otherwise)
trim (where, set)
foreach

1.1 什么是动态SQL?

动态SQL就是 指根据不同的条件生成不同的SQL语句

1.2 搭建环境

 1.2.1 创建表

执行此sql语句

CREATE TABLE `blog`(`id` VARCHAR(50) NOT NULL COMMENT '博客id',`title` VARCHAR(100) NOT NULL COMMENT '博客',`author` VARCHAR(30) NOT NULL COMMENT '博客作者',`create_time` DATETIME NOT NULL COMMENT '创建时间',`views` INT(30) NOT NULL COMMENT '浏览量')ENGINE=INNODB DEFAULT CHARSET=utf8

执行结果:

怎么在Mybatis中搭建动态SQL环境

1.2.2 创建一个基础工程

怎么在Mybatis中搭建动态SQL环境

1.2.2.1 导包

pom.xml

<dependencies>        <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->        <dependency>            <groupId>org.projectlombok</groupId>            <artifactId>lombok</artifactId>            <version>1.18.12</version>            <scope>provided</scope>        </dependency>    </dependencies>

2.2 编写配置文件

mybatis-config.xml

<!--    引入外部配置文件-->    <properties resource="db.properties"/>    <settings>        <setting name="logImpl" value="STDOUT_LOGGING"/>        <!--       是否开启驼峰命名自动映射,即从经典数据库列名 A_COLUMN 映射到经典 Java 属性名 aColumn。 -->        <setting name="mapUnderscoreToCamelCase" value="true"/>    </settings>    <typeAliases>        <typeAlias type="com.tian.pojo.Blog" alias="Blog"/>    </typeAliases>

1.2.2.3 编写实体类

Blog.java

package com.tian.pojo;import lombok.Data;import java.util.Date;@Datapublic class Blog {    private String id;    private String title;    private String author;    private Date createTime; //属性名和字段名不一致 数据库是 create_time    private int views;}

1.2.2.4 编写实体类对应Mapper接口和Mapper.XML文件

BlogMapper.java

package com.tian.dao;import com.tian.pojo.Blog;public interface BlogMapper {    //    插入数据    int addBlog(Blog blog);}

BlogMapper.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.tian.dao.BlogMapper">    <insert id="addBlog" parameterType="Blog">        insert into mybatis.blog(id, title, author, create_time, views)        values (#{id}, #{title}, #{author}, #{createTime}, #{views});    </insert></mapper>

1.2.2.5 编写IDUtils .java用于生成随机的ID

IDUtils .java

package com.tian.util;import org.junit.Test;import java.util.UUID;@SuppressWarnings("all") // 忽略所有警告public class IDUtils {    public static String getId() {        return UUID.randomUUID().toString().replaceAll("-", "");    }    @Test    public void test() {        System.out.println(getId());        System.out.println(getId());        System.out.println(getId());        System.out.println(getId());        System.out.println(getId());        System.out.println(getId());    }}

运行结果:

怎么在Mybatis中搭建动态SQL环境

1.2.2.6 向表中插入数据

Test.java

import com.tian.dao.BlogMapper;import com.tian.pojo.Blog;import com.tian.util.IDUtils;import com.tian.util.MybatisUtils;import org.apache.ibatis.session.SqlSession;import java.util.Date;public class Test {    @org.junit.Test    public void test() {        SqlSession sqlSession = MybatisUtils.getSqlSession();        BlogMapper mapper = sqlSession.getMapper(BlogMapper.class);        Blog blog = new Blog();        blog.setId(IDUtils.getId());        blog.setTitle("Mybatis");        blog.setAuthor("天天天");        blog.setCreateTime(new Date());        blog.setViews(9999);        mapper.addBlog(blog);        blog.setId(IDUtils.getId());        blog.setTitle("Java");        mapper.addBlog(blog);        blog.setId(IDUtils.getId());        blog.setTitle("Spring");        mapper.addBlog(blog);        blog.setId(IDUtils.getId());        blog.setTitle("微服务");        mapper.addBlog(blog);        sqlSession.close();    }}

运行结果:

怎么在Mybatis中搭建动态SQL环境
怎么在Mybatis中搭建动态SQL环境
现在我们吧表中的数据稍微更改下
怎么在Mybatis中搭建动态SQL环境

看完上述内容,你们对怎么在Mybatis中搭建动态SQL环境有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网行业资讯频道,感谢大家的支持。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯