【Java】【MySQL】数据库存储的日期是字符类型,查询指定日期时间区间是用数据库的方法STR_TO_DATE().

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
RDS Agent(兼容Hermes Agent),2核4GB
简介: 【Java】【MySQL】数据库存储的日期是字符类型,查询指定日期时间区间是用数据库的方法STR_TO_DATE().

一、问题与分析


遇到的问题:找出xxx到期剩余x天的所有服务


场景限制条件:数据库表里存的是字符类型的日期格式(yyyy-MM-dd)


分析:当前需要解决的是表里的字段存储日期格式的类型是字符类型,最终想到的是利用STR_TO_DATE()的方法。(最后完美提高了几倍效率)


二、实现过程


一个表数据与表结构,如下图:


微信截图_20220519194225.png


执行sql语句


SELECT * from t_doc_info WHERE 1 = 1 
and (STR_TO_DATE(remind_day,'%Y-%m-%d') 
BETWEEN STR_TO_DATE('2021-12-21','%Y-%m-%d') and STR_TO_DATE('2021-12-21','%Y-%m-%d'))
and is_del = 0


执行结果


微信截图_20220519194235.png


其中,STR_TO_DATE('2021-12-21','%Y-%m-%d')方法是把字符串类型的时间转化为时间格式,最后利用BETWEEN去求出剩余多少天的所有服务。


BETWEEN就是在这两个数之间的符合条件,没什么好说的。


运行java的代码(这里只是简单写核心的内容)


public static void main(String[] args) {
  Date date = new Date();
  SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  String startDay = sdf.format(date);
  Calendar ca = Calendar.getInstance();
  ca.add(Calendar.DATE, 7); // 当前计算即将过期是剩余7天内(包括)
  date = ca.getTime();
  String endDay = sdf.format(date);
  System.err.println("即将过期,过期时间在:" + startDay + "和" + endDay + "之间");
}


运行结果(这里只是简单写核心的内容)


微信截图_20220519194253.png


sql语句转成jdbc写法(这里只是简单写核心的内容)


import org.springframework.jdbc.core.JdbcTemplate;
public class TestDemoServiceImpl{
  @Autowired
  private JdbcTemplate jdbcTemplate;
  public List<DocBean> getExpireDocList(String startDay, String endDay,
      String userIdListStr) {
    StringBuffer sb = new StringBuffer();
    sb.append("SELECT * from t_doc_info");
    sb.append(" WHERE 1 = 1");
    if (StringUtils.isNotBlank(userIdListStr)) {
      sb.append(" AND user_id IN(" + userIdListStr + ")");
    }
    if (StringUtils.isNotBlank(startDay) && StringUtils.isNotBlank(endDay)) 
                { // 指定过期时间期间(格式为:yyyy-MM-dd)STR_TO_DATE()字符转为时间类型
      sb.append("AND (STR_TO_DATE(expire_day,'%Y-%m-%d') BETWEEN STR_TO_DATE('" + startDay + "','%Y-%m-%d') and STR_TO_DATE('" + endDay + "','%Y-%m-%d'))");
    }
    sb.append(" AND is_del = 0");
    try {
      return jdbcTemplate.query(sb.toString(),
          new BeanPropertyRowMapper<DocBean>(DocBean.class));
    } catch (DataAccessException e) {
      e.printStackTrace();
      return null;
    }
  }
}


扩展如果要添加条件,指定用户可以这样(例如:指定userId为1001、1002、1003的用户服务情况)


SELECT * from t_doc_info WHERE 1 = 1 
and (STR_TO_DATE(expire_day,'%Y-%m-%d') BETWEEN STR_TO_DATE('2021-12-21','%Y-%m-%d') and STR_TO_DATE('2021-12-21','%Y-%m-%d'))
and is_del = 0
and user_id in ('1001','1002','1003')


文章小尾巴


文章写作、模板、文章小尾巴、参与活动中奖等技巧可参考文章:《写作“小心思”》


  感谢你看到最后,最后再说两点~


  ①如果你持有不同的看法,欢迎你在文章下方进行留言、评论。

  ②如果对你有帮助,或者你认可的话,欢迎给个小点赞,支持一下~


  我是南方者,一个热爱计算机更热爱祖国的南方人。


  (文章内容仅供学习参考,如有侵权,非常抱歉,请立即联系作者删除。)



相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
10月前
|
SQL 缓存 监控
MySQL缓存机制:查询缓存与缓冲池优化
MySQL缓存机制是提升数据库性能的关键。本文深入解析了MySQL的缓存体系,包括已弃用的查询缓存和核心的InnoDB缓冲池,帮助理解缓存优化原理。通过合理配置,可显著提升数据库性能,甚至达到10倍以上的效果。
|
9月前
|
Java
Java语言实现字母大小写转换的方法
Java提供了多种灵活的方法来处理字符串中的字母大小写转换。根据具体需求,可以选择适合的方法来实现。在大多数情况下,使用 String类或 Character类的方法已经足够。但是,在需要更复杂的逻辑或处理非常规字符集时,可以通过字符流或手动遍历字符串来实现更精细的控制。
531 18
|
10月前
|
算法 安全 Java
除了类,Java中的接口和方法也可以使用泛型吗?
除了类,Java中的接口和方法也可以使用泛型吗?
272 11
|
9月前
|
Java 编译器 Go
【Java】(5)方法的概念、方法的调用、方法重载、构造方法的创建
Java方法是语句的集合,它们在一起执行一个功能。方法是解决一类问题的步骤的有序组合方法包含于类或对象中方法在程序中被创建,在其他地方被引用方法的优点使程序变得更简短而清晰。有利于程序维护。可以提高程序开发的效率。提高了代码的重用性。方法的名字的第一个单词应以小写字母作为开头,后面的单词则用大写字母开头写,不使用连接符。例如:addPerson。这种就属于驼峰写法下划线可能出现在 JUnit 测试方法名称中用以分隔名称的逻辑组件。
360 4
|
9月前
|
编解码 Java 开发者
Java String类的关键方法总结
以上总结了Java `String` 类最常见和重要功能性方法。每种操作都对应着日常编程任务,并且理解每种操作如何影响及处理 `Strings` 对于任何使用 Java 的开发者来说都至关重要。
485 5
|
10月前
|
SQL 关系型数据库 MySQL
MySQL的查询操作语法要点
储存过程(Stored Procedures) 和 函数(Functions) : 储存过程和函数允许用户编写 SQL 脚本执行复杂任务.
367 14
|
10月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
10月前
|
SQL 关系型数据库 MySQL
MySQL的查询操作语法要点
以上概述了MySQL 中常见且重要 的几种 SQL 查询及其相关概念 这些知识点对任何希望有效利用 MySQL 进行数据库管理工作者都至关重要
242 15
|
10月前
|
Java 开发者
Java 函数式编程全解析:静态方法引用、实例方法引用、特定类型方法引用与构造器引用实战教程
本文介绍Java 8函数式编程中的四种方法引用:静态、实例、特定类型及构造器引用,通过简洁示例演示其用法,帮助开发者提升代码可读性与简洁性。
|
10月前
|
SQL Java 关系型数据库
Java连接MySQL数据库环境设置指南
请注意,在实际部署时应该避免将敏感信息(如用户名和密码)硬编码在源码文件里面;应该使用配置文件或者环境变量等更为安全可靠地方式管理这些信息。此外,在处理大量数据时考虑使用PreparedStatement而不是Statement可以提高性能并防止SQL注入攻击;同时也要注意正确处理异常情况,并且确保所有打开过得资源都被正确关闭释放掉以防止内存泄漏等问题发生。
443 13

推荐镜像

更多