mybatis plus中如何编写sql语句

目录
  • sql语句是写在对应的xml文件中
  • mybatis plus sql语句集合
    • 获取数据库中某个varchar字段的最大值
    • 日期格式转换
    • 字符串拼接
    • 查询年份的当前年份的后面一年
    • 查询获取当前年份
    • left,right函数返回args最左边、右边的length个字符串
    • 当前日期的前三个月日期
    • 截取某一个字段中以某个字符开始截取

sql语句是写在对应的xml文件中

首先要解决maven默认不加载xml文件的问题

1.首先要写入相关配置文件

在pom 导入下面内容

 <build>
        <resources>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.xml</include>
                </includes>
            </resource>
            <resource>
                <directory>src/main/resources</directory>
            </resource>
        </resources>
    </build>

在application中写入如下内容

mybatis-plus:
  mapper-locations: classpath*:**/xml/*.xml

2.在对应的serviceimpl中调用baseMapper 接口

应为在mybatis plus 中对应的serviceImpl 接口继承自对应的mapper接口,mapper接口又继承自baseMapper 接口。

比如说

baseMapper.countRegisterDay(day)

3.在mapper文件中编写对应的接口

 Integer countRegisterDay(String day);

4.在对应的xml 中编写sql语句

id 为方法的名字。resultType 为方法返回的类型

<?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.boshrong.ucentor.mapper.UcenterMemberMapper">
    <select id="countRegisterDay" resultType="java.lang.Integer">
        select count(*) from ucenter_member um where DATE (um.gmt_create)=#{day}
    </select>

</mapper>

注意若传入的值有多个参数怎么解决?

比如说方法为

 Integer countRegisterDay(String day,String time1);

sql 中获取多个值的方法可以有两种

1.方法一 ,通过索引获取

#{0} 获取day的值, #{1} 获取time1的值

2.方法二, 通过@Param获取

Integer countRegisterDay(@Param ("aa")String day,@Param ("bb")String time1);
  • #{aa},#{bb} 获取
  • #{} 与 ${} 的区别
  • #{} 是预编译处理,是占位符。 Mybatis 在处理 #{} 时,会将sql 中的#{} 替换成?号,调用PreparedStatement 来赋值。
  • ${} 是字符串替换,是拼接符。就是会将 KaTeX parse error: Expected 'EOF', got '#' at position 30: …Statement 来赋值。 #̲方式能够很大程度防止sql注入…方式。

mybatis plus sql语句集合

获取数据库中某个varchar字段的最大值

max(CONVERT(stat_date,UNSIGNED))

日期格式转换

DATE_FORMAT(update_time,‘%Y-%m-%d %T')

字符串拼接

concat(#{year},‘Y')

查询年份的当前年份的后面一年

DATE_FORMAT(DATE_SUB(CURDATE(),interval -1 year),‘%Y')

查询获取当前年份

DATE_FORMAT(CURDATE(),‘%Y')

left,right函数返回args最左边、右边的length个字符串

right(args, 2)

当前日期的前三个月日期

pay_time <![CDATA[<]]> now() - INTERVAL 3 MONTH AND now()

截取某一个字段中以某个字符开始截取

  • 以从后面开始第一个横杠为分割截取
SUBSTRING_INDEX( dep_name, ‘-',- 1 ) depName
  • 以第一个横杠为分割截取
SUBSTRING_INDEX( dep_name, ‘-',1 ) depName

IFNULL() 函数

IFNULL(expression, alt_value)如果第一个参数的表达式 expression 为 NULL,则返回第二个参数的备用值。

  • 返回列表中的最大值
GREATEST(expr1, expr2, expr3, …)
  • 返回列表中的最小值
LEAST(expr1, expr2, expr3, …)
  • 计算日期 d1->d2 之间相隔的天数
DATEDIFF(d1,d2)
  • 如果表达式 expr 成立,返回结果 v1;否则,返回结果 v2。
IF(expr,v1,v2)

find_in_set(str,strlist)

  • find_in_set判断是否包含某个字符串
  • str 要查询的字符串
  • strlist 字段名 参数以”,”分隔 如 (1,2,6,8,10,22)
  • 匹配个字段是否为纯数字 0为匹配纯数字 1为匹配不是纯数字
AND (TRIM(str) REGEXP ‘[^0-9.]') = 0
  • 将字符串转换为int数字类型
CAST(right(yearmth, 2) AS SIGNED)
  • 动态获取数据库某个字段来作为条件
FIND_IN_SET (year_id,(SELECT
GROUP_CONCAT(DISTINCT LEFT(字段, 4))
from table))

locate()函数

  • locate(subStr,string) :函数返回subStr在string中出现的位置
  • 只要找到返回的结果都大于0(即使是查询的内容就是最开始部分),没有查找到才返回0;
// 如果字符串 string 包含 subStr
locate(subStr,string) > 0
// 如果字符串 string 不包含 subStr
locate(subStr,string) = 0

locate()函数实现模糊查询

select * from user where locate('王',name)

假如现在需求是找出所有名字中含有王,但是不姓王的人找出来,我们用下面那种实现方式如下:

select * from user where locate('王',name,2)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • springboot+mybatis-plus 两种方式打印sql语句的方法

    1.注解方式,yml文件配置上以下就可以直接使用 mybatis-plus: mapper-locations: classpath:mapper/*.xml configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl 2.这一种网上没有,搜过好多资料都没有,我是配置多数据源,所以是在代码中写的config那么yml文件就是失效的,只能一个一个配置,到了打印sql的时候,就怎么都是找不到,后来设置的源码找到灵感,发现可

  • Mybatis-Plus的SQL语句组拼原理说明

    记录查找自动组拼SQL语句的过程 首先在BaseMapper其中的一个方法下打个断点 在断点显示的值栏找到相关的SQL 发现SQL语句在MappedStatement对象中,而sqlSource存的就是相关的sql语句 然后在MappedStatement这个对象打断点,看看到底是哪个对象对它进行了操作 发现是AutoSqlInjector创建了MappedStatement 在AutoSqlInjector对象找到与selectById相关的一个方法,打断点 SqlSource果然在这里创建出

  • mybatis-plus的sql语句打印问题小结

    目录 第一种方式: 第二种方式: mybatis-plus使用时候的小问题记录. 在使用mybatis-plus的时候需要把sql的语句打印出来,查看执行的成功与否,在以前的项目的时候使用过这种各样的方式,在使用mybatis-plus上面也使用过两种方式,今天将常用的方式拷贝过来之后,发现没有发生效果(开始的时候以为是使用配置中心nacos导致问题,最后经过仔细的检查发现是单词拼错了),所以在这里记录一下. 第一种方式: mybatis-plus: configuration: log-imp

  • mybatis-plus配置控制台打印完整带参数SQL语句的实现

    问题背景 通常我们开发的时候,需要联合控制台和Navicat/PLSQL等工具进行语句的拼接检查,如果只是输出了一堆???,那么将极大降低我们的效率.因此我们需要输出完整的SQL语句以便调试. update 2020-July : 新增官方p6spy打印分析sql语句方案 解决方案(StdOutImpl) 请注意: 部分朋友反馈不生效,估计跟引入的包有一定关系,druid+mybatis-plus-boot-starter 就亲测有用.请检查是否有log4j相关实现类. 如果是applicati

  • mybatis-plus 使用Condition拼接Sql语句各方法的用法

    mybatis-plus Condition拼接Sql语句各方法 1.setSqlSelect-用于添加查询的列信息 public Wrapper<T> setSqlSelect(String... columns) { StringBuilder builder = new StringBuilder(); String[] arr = columns; int len = columns.length; for(int i = 0; i$ < len; ++i$) { String

  • MyBatis-Plus 自定义sql语句的实现

    一.引言 Good Good Study,Day Day Up,童鞋点个关注,不迷路,么么哒--- MP自带的条件构造器虽然很强大,有时候也避免不了写稍微复杂一点业务的sql,那么那么今天说说MP怎么自定义sql语句吧. 二.配置 自定义的sql当然是写在XML文件中的啦,那么首先来定义xml文件的位置,在yml配置文件如下 mybatis-plus: # 如果是放在src/main/java目录下 classpath:/com/*/*/mapper/*Mapper.xml # 如果是放在res

  • MyBatisPlus 自定义sql语句的实现

    一.引言 Good Good Study,Day Day Up MP自带的条件构造器虽然很强大,有时候也避免不了写稍微复杂一点业务的sql,那么那么今天说说MP怎么自定义sql语句吧. 二.配置 自定义的sql当然是写在XML文件中的啦,那么首先来定义xml文件的位置,在yml配置文件如下 mybatis-plus: # 如果是放在src/main/java目录下 classpath:/com/*/*/mapper/*Mapper.xml # 如果是放在resource目录 classpath:

  • mybatis plus中如何编写sql语句

    目录 sql语句是写在对应的xml文件中 mybatis plus sql语句集合 获取数据库中某个varchar字段的最大值 日期格式转换 字符串拼接 查询年份的当前年份的后面一年 查询获取当前年份 left,right函数返回args最左边.右边的length个字符串 当前日期的前三个月日期 截取某一个字段中以某个字符开始截取 sql语句是写在对应的xml文件中 首先要解决maven默认不加载xml文件的问题 1.首先要写入相关配置文件 在pom 导入下面内容  <build>      

  • Mybatis中的动态SQL语句解析

    这篇文章主要介绍了Mybatis中的动态SQL语句解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Mybatis中配置SQL有两种方式,一种是利用xml 方式进行配置,一种是利用注解进行配置. Mybatis使用注解配置SQL,但是由于配置功能受限,而且对于复杂的SQL而言可读性很差,所以很少使用. Mybatis常用xml配置的方式,使用xml的几个简单的元素,便能完成动态SQL的功能,大量的判断都可以在mybaties的映射xml里面配

  • MyBatis Log 插件无法显示SQL语句的原因解析

    Mybatis有什么用 前两天跟阿里的大牛聊天,他讲到对于性能要求高,需求变化多的互联网项目来说,用在sql优化上的开发时间是大头,有时候代码写出来一小时,优化反反复复可能要几个星期,这时候Mybatis这种配置比较灵活的框架优势就显现了!Mybatis为什么在国内这么流行? 1. 什么是Mybatis? MyBatis是支持定制化sql.存储过程以及高级映射的优秀的持久层框架.MyBatis避免了几乎所有的JDBC代码和手工设置参数以及抽取结果集.MyBatis使用简单的XML或注解来配置和映

  • 10种Java开发者编写SQL语句时常见错误

    Java开发者对于面向对象编程思维与命令行编程思维的协调程度,取决于他们如下几种能力的水平: 技巧(任何人都可以编写命令行形式的代码) 教条(有的人使用"模式 - 模式"的方式,即模式无处不在,并以名字作为标识) 情绪状况(在初期,真正面向对象形式的代码比起命令式代码会更加难懂.) 但是,当Java开发人员编写SQL语句时,一切都变得不同了.SQL是一种说明式语言,与面向对象思想和命令式思想无关.在SQL语言中,查询非常容易表达.但它也不是那么容易以最佳或最正确地方式编写出来.开发人员

  • Mybatis模糊查询和动态sql语句的用法

    Mybatis 模糊查询和动态sql语句 模糊查询 对数据库最常用的操作就是查询了,但是如何使用Mybatis进行模糊查询呢?下面先看一个简单的模糊查询 <select id="select01" resultMap="BasicResultMap"> SELECT * FROM oa_employee WHERE emp_name LIKE #{asd} </select> 这是一条伪模糊查询, 因为没有实现真正的模糊 "%&qu

  • 浅谈MyBatis 如何执行一条 SQL语句

    前言 Mybatis 是 Java 开发中比较常用的 ORM 框架.在日常工作中,我们都是直接通过 Spring Boot 自动配置,并直接使用,但是却不知道 Mybatis 是如何执行一条 SQL 语句的,而这篇文章就是来揭开 Mybatis 的神秘面纱. 基础组件 我们要理解 Mybatis 的执行过程,就必须先了解 Mybatis 中都有哪一些重要的类,这些类的职责都是什么? SqlSession 我们都很熟悉,它对外提供用户和数据库之间交互需要使用的方法,隐藏了底层的细节.它默认是实现类

  • Mybatis超级强大的动态SQL语句大全

    目录 1. If 语句 2. Where语句 2.1 和 where 元素等价的自定义 trim 元素 3. Set语句 3.1 与 set 元素等价的自定义 trim 元素 4. Choose语句 5. Foreach语句 6. SQL片段 7. Bind元素 附:MyBatis配置动态SQL语句 总结 1. If 语句 需求:根据作者名字和博客名字来查询博客!如果作者名字为空,那么只根据博客名字查询,反之,则根据作者名来查询 <!--需求1: 根据作者名字和博客名字来查询博客! 如果作者名字

  • thinkPHP框架中执行原生SQL语句的方法

    本文实例讲述了thinkPHP框架中执行原生SQL语句的方法.分享给大家供大家参考,具体如下: 怎样在thinkphp里面执行原生的sql语句? $Model = new Model();//或者 $Model = D(); 或者 $Model = M(); $sql = "select * from `order`"; $voList = $Model->query($sql); 只是需要new一个空的模型继承Model中的方法. 注意query是查功能,execute是增删改

  • Mybatis基于注解形式的sql语句生成实例代码

    对其做了些优化,但此种sql生成方式仅适用于复杂程度不高的sql,所以实用性不是很高,仅仅是写着玩的,知道点mybatis的注解形式的使用方式,可能以后会逐渐完善起来.第一次写博客,写的简单点. package com.bob.config.mvc.mybatis; import java.lang.annotation.Documented; import java.lang.annotation.ElementType; import java.lang.annotation.Retenti

  • django中使用原生sql语句的方法步骤

    raw # row方法:(掺杂着原生sql和orm来执行的操作) res = CookBook.objects.raw('select id as nid from epos_cookbook where id>%s', params=[1, ]) print(res.columns) # ['nid'] print(type(res)) # <class 'django.db.models.query.RawQuerySet'> # 在select里面查询到的数据orm里面的要一一对应

随机推荐