iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在Mybatis中搭建动态SQL环境
  • 412
分享到

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

2023-06-14 23:06:36 412人浏览 安东尼
摘要

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

今天就跟大家聊聊有关怎么在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环境有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网精选频道,感谢大家的支持。

--结束END--

本文标题: 怎么在Mybatis中搭建动态SQL环境

本文链接: https://www.lsjlt.com/news/275717.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在Mybatis中搭建动态SQL环境
    今天就跟大家聊聊有关怎么在Mybatis中搭建动态SQL环境,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1. Mybatis–动态SQL动态 SQL 是 MyBatis 的强大特性...
    99+
    2023-06-14
  • Mybatis 动态SQL搭建环境的全过程
    1. Mybatis–动态SQL 动态 SQL 是 MyBatis 的强大特性之一。如果你使用过 JDBC 或其它类似的框架,你应该能理解根据不同条件拼接 SQL 语句有多痛苦,例如...
    99+
    2022-11-12
  • idea怎么搭建mybatis环境
    要在IntelliJ IDEA中搭建MyBatis环境,请按照以下步骤进行操作:1. 在IntelliJ IDEA中创建一个新的Ja...
    99+
    2023-10-10
    idea mybatis
  • python自动化环境怎么搭建
    要搭建Python自动化环境,可以按照以下步骤进行: 安装Python:首先需要下载并安装Python解释器。可以从Python...
    99+
    2023-10-22
    python
  • 怎么在MyBatis中使用动态SQL标签
    这篇文章将为大家详细讲解有关怎么在MyBatis中使用动态SQL标签,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.MyBatis动态SQLMyBatis 的强大特性之一便是它的动态 SQ...
    99+
    2023-06-14
  • 怎么在Server上搭建PHP环境
    本文小编为大家详细介绍“怎么在Server上搭建PHP环境”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么在Server上搭建PHP环境”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。第一步:安装Apache在...
    99+
    2023-07-06
  • 怎么在MacBook中搭建一个python3.7环境
    怎么在MacBook中搭建一个python3.7环境?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。第一、下载Python最新版本安装包pyth...
    99+
    2022-10-18
  • 怎么在WINDOWS系统中搭建MYSQL环境
    本篇文章给大家分享的是有关怎么在WINDOWS系统中搭建MYSQL环境,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、下载安装包2、配置环境...
    99+
    2022-10-18
  • MyBatis中怎么实现动态SQL!
    这篇文章将为大家详细讲解有关MyBatis中怎么实现动态SQL!,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、if标签if是最常用标签,经常用在判断语句...
    99+
    2022-10-18
  • 怎么搭建Python+Selenuim自动化环境
    这篇文章主要介绍“怎么搭建Python+Selenuim自动化环境”,在日常操作中,相信很多人在怎么搭建Python+Selenuim自动化环境问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么搭建Pytho...
    99+
    2023-06-19
  • Linux中怎么搭建Python2.7环境
    这篇“Linux中怎么搭建Python2.7环境”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Linux中怎么搭建Pytho...
    99+
    2023-06-27
  • centos中怎么搭建php环境
    要在CentOS上搭建PHP环境,您可以按照以下步骤进行操作: 更新系统: sudo yum update 安装Apache...
    99+
    2023-10-27
    centos php
  • Centos7中怎么搭建k8s环境
    Centos7中怎么搭建k8s环境,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1. 安装kubeadm、kubelet、kubectl由于官方k8s源在google,国内...
    99+
    2023-06-16
  • python在线编程环境怎么搭建
    要搭建Python在线编程环境,可以选择以下几种方法:1. 使用Jupyter Notebook:Jupyter Notebook是...
    99+
    2023-09-20
    python
  • Docker在Windows环境中怎么搭建和使用
    本文小编为大家详细介绍“Docker在Windows环境中怎么搭建和使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Docker在Windows环境中怎么搭建和使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧...
    99+
    2023-07-05
  • node.js自动化部署环境怎么搭建
    本篇内容介绍了“node.js自动化部署环境怎么搭建”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、docker部分1.1、docker简...
    99+
    2023-07-04
  • Mybatis在注解上怎么实现动态SQL
    本文小编为大家详细介绍“Mybatis在注解上怎么实现动态SQL”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mybatis在注解上怎么实现动态SQL”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。在注解上实现动...
    99+
    2023-07-02
  • 浅析怎么在本地搭建Git环境
    随着软件开发的发展,代码管理变得至关重要。Git是当今最受欢迎的版本控制系统之一,广泛应用于开源和私有项目。在本文中,我们将介绍如何在本地搭建Git环境,以便更好地管理和协作您的代码。准备工作在开始之前,需要先安装Git。如果您尚未安装Gi...
    99+
    2023-10-22
  • 怎么在deepin上搭建Go开发环境
    本篇内容主要讲解“怎么在deepin上搭建Go开发环境”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么在deepin上搭建Go开发环境”吧!1. Go安装包下载下载Go安装包 go1.12.9...
    99+
    2023-06-05
  • 怎么在vscode中搭建一个golang开发环境
    怎么在vscode中搭建一个golang开发环境?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。vscode有什么用Visual Studio Code 是一个运行于 OS X,...
    99+
    2023-06-07
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作