数据库管理-根据日期字段进行数据筛选更新数据

news2024/11/20 8:13:55

项目场景

数据插入、更新、查询

数据库中一张审计表格用来记录数据的操作包括数据的id,数据名称sjmc,数据状态sjzt,数据创建时间createtime,数据更新时间updatetime

具体需求如下:

  • 根据数据名称更新sjztupdatetime
  • 根据更新时间选取数据修改sjzt。

环境介绍

  • PostgreSQL
  • 瀚高数据库(HighgoDB)

问题描述及方法

根据时间查询

  • 1. 数据库中有一个审计表格audit,表格内更新时间updatetime(数据类型为timestamp),现在我想根据时间进行筛选

SELECT *
FROM audit
WHERE DATE(updatetime) = CURRENT_DATE;

#或者

SELECT *
FROM audit
WHERE DATE(updatetime) = '2024-11-19';


#可以利用当天的起始时间(00:00:00)到结束时间(23:59:59)来确定一个时间范围,
SELECT *
FROM audit
WHERE updatetime BETWEEN CURRENT_DATE::timestamp AND (CURRENT_DATE + INTERVAL '1 DAY')::timestamp - INTERVAL '1 SECOND';

  • DATE(updatetime) 会从 updatetime 列的每个 timestamp 值中提取出日期部分,比如 2024-11-19 10:30:00 这样的时间戳,会提取出 2024-11-19 这一日期值。
  • CURRENT_DATE 是一个获取当前日期(不含时间部分)的函数,例如在 2024 年 11 月 19 日执行查询时,它就代表 2024-11-19 。
  • CURRENT_DATE::timestamp 将当前日期转换为 timestamp 类型,实际上就是当天的起始时间点,例如 2024-11-19 00:00:00 。
  • (CURRENT_DATE + INTERVAL ‘1 DAY’)::timestamp - INTERVAL ‘1 SECOND’ 先将当前日期加一天,然后转换为 timestamp 类型,再减去 1 秒,相当于获取到了当天最后时刻(2024-11-19 23:59:59),整体 BETWEEN 操作符就筛选出了 updatetime 列值在这个当天时间范围内的所有行。
  • WHERE 子句则是筛选出 updatetime 列日期部分等于当前日期的所有行记录。
  • 2. 选择updatetime 列的值与当前日期和指定时间(16:07)的数据
SELECT *
FROM audit
WHERE updatetime = CURRENT_DATE::timestamp + '16:07'::time;

# 使用 DATE_TRUNC() 函数结合时间比较(按分钟截断)
SELECT *
FROM audit
WHERE DATE_TRUNC('minute', updatetime) = '2024-10-10 16:07:00'::timestamp;

  • CURRENT_DATE::timestamp 首先获取当前日期,并将其转换为 timestamp 类型,这相当于得到了当天的起始时间点,例如在 2024 年 11 月 19 日执行查询时,就会得到 2024-11-19 00:00:00 这样的时间戳值。
  • ‘16:07’::time 是将字符串表示的时间 16:07 转换为 time 类型。
  • 通过加法操作将两者合并,就构造出了代表当天 16:07 这个具体时刻的时间戳(例如 2024-11-19 16:07:00 ),WHERE 子句利用这个构造好的时间戳去筛选出 updatetime 列与之完全相等的行记录。
  • ‘2024-10-10 16:07:00’::timestamp 这个表达式是将字符串形式表示的时间 2024-10-10 16:07:00 转换为 timestamp 类型,以便可以和 updatetime 列中同样是 timestamp 类型的值进行比较。
  • DATE_TRUNC(‘minute’, updatetime) 会按照分钟对 updatetime 列中的每个时间戳值进行截断操作,例如对于 2024-10-10 16:07:30 这样的时间戳,经过该函数处理后就会变为 2024-10-10 16:07:00 ,也就是舍去秒等更细的时间部分,只保留到分钟精度。
  • 3.根据选取2024-10-10 16:07左右5分钟的数据
##可以使用获取以 2024-10-10 16:07 为中心,前后几分钟的数据,可以使用 BETWEEN 操作符结合时间的运算来实现

SELECT *
FROM audit
WHERE updatetime BETWEEN ('2024-10-10 16:07:00'::timestamp - INTERVAL '5 minutes')
                       AND ('2024-10-10 16:07:00'::timestamp + INTERVAL '5 minutes');


##按照秒范围来选取(包含 16:07 前后30秒的数据)                      
SELECT *
FROM audit
WHERE updatetime BETWEEN ('2024-10-10 16:07:00'::timestamp - INTERVAL '30 seconds')
                       AND ('2024-10-10 16:07:00'::timestamp + INTERVAL '30 seconds');

#获取以 2024-10-10 16:07 为中心,前后各 2 小时这个时间区间内的数据
SELECT *
FROM audit
WHERE updatetime BETWEEN ('2024-10-10 16:07:00'::timestamp - INTERVAL '2 hours')
                       AND ('2024-10-10 16:07:00'::timestamp + INTERVAL '2 hours');


##使用比较运算符(>、<、>=、<=)组合(适用于更灵活的区间界定,比如不包含边界值等情况)
SELECT *
FROM audit
WHERE updatetime >= ('2024-10-10 16:07:00'::timestamp - INTERVAL '2 hours')
  AND updatetime <= ('2024-10-10 16:07:00'::timestamp + INTERVAL '2 hours');

  • ‘2024-10-10 16:07:00’::timestamp 先将字符串形式表示的时间 2024-10-10 16:07:00 转换为 timestamp 类型,代表 2024-10-10 16:07 这个时刻的时间戳。
  • INTERVAL ‘5 minutes’ 表示一个时间间隔为 5 分钟,通过减法和加法运算,分别得到了这个时刻往前推 5 分钟(2024-10-10 16:02:00 )和往后推 5 分钟(2024-10-10 16:12:00 )的时间戳。
  • INTERVAL ‘30 seconds’ 表示 30 秒的时间间隔
  • INTERVAL ‘2 hours’ 表示一个时间间隔为 2 小时
  • BETWEEN 操作符则筛选出 updatetime 列中时间戳值处于这两个时间戳所界定的区间(即从 2024-10-10 16:02:00 到 2024-10-10 16:12:00 )内的所有行记录。

  • 4.插入数据时,当 id 已经存在就跳过插入操作,继续执行后面的语句,可以使用 ON CONFLICT 子句来实现

INSERT INTO tab_sjly("id", "sjmc")
VALUES
    ('1c879377-991f-4b67-a78a-8bc0dd804657', 'XZQ_shi'),
    ('e7a2ddec-775b-40b3-88db-331f60fb3931', 'XZQ_地级市行政中心'),
    ('0749e643-b636-4ee3-960f-30c647a09b36', 'a_gsjyrk')
ON CONFLICT ("id") DO NOTHING;

  • ON CONFLICT (“id”) 这部分表示当插入的数据在 “id” 列出现冲突时(也就是要插入的 id 值在表中已经存在了),进行后续的指定操作。
  • DO NOTHING 就是指定的操作,表示在遇到 id 冲突的情况下,什么都不做,直接跳过当前这条插入语句对应的插入行为,然后继续执行后面的插入语句或者其他相关的后续语句(如果有的话)。

小结

  1. 使用 BETWEEN 操作符(适用于包含边界值的区间查询)
  2. 只查询大于起始时间且小于结束时间的数据(不包含边界值),查询大于等于起始时间且小于等于结束时间的数据(包含边界值):使用比较运算符(>、<、>=、<=)组合(适用于更灵活的区间界定,比如不包含边界值等情况)。
  3. 使用 DATE_TRUNC() 函数结合时间区间查询(常用于按照特定时间精度来界定区间,比如按天、按小时等)
  4. ON CONFLICT (“id”) DO NOTHING 用于解决已经插入的数据受到键值约束插入失败的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2243918.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PgSQL即时编译JIT | 第1期 | JIT初识

PgSQL即时编译JIT | 第1期 | JIT初识 JIT是Just-In-Time的缩写&#xff0c;也就是说程序在执行的时候生成可以执行的代码&#xff0c;然后执行它。在介绍JIT之前&#xff0c;需要说下两种执行方式&#xff1a;解释执行和编译执行。其中解释执行是通过解释器&#xff0c;将代码逐…

力扣-Hot100-数组【算法学习day.37】

前言 ###我做这类文档一个重要的目的还是给正在学习的大家提供方向&#xff08;例如想要掌握基础用法&#xff0c;该刷哪些题&#xff1f;&#xff09;我的解析也不会做的非常详细&#xff0c;只会提供思路和一些关键点&#xff0c;力扣上的大佬们的题解质量是非常非常高滴&am…

DataStream编程模型之数据源、数据转换、数据输出

Flink之DataStream数据源、数据转换、数据输出&#xff08;scala&#xff09; 0.前言–数据源 在进行数据转换之前&#xff0c;需要进行数据读取。 数据读取分为4大部分&#xff1a; &#xff08;1&#xff09;内置数据源&#xff1b; 又分为文件数据源&#xff1b; socket…

爬虫开发工具与环境搭建——使用Postman和浏览器开发者工具

第三节&#xff1a;使用Postman和浏览器开发者工具 在网络爬虫开发过程中&#xff0c;我们经常需要对HTTP请求进行测试、分析和调试。Postman和浏览器开发者工具&#xff08;特别是Network面板和Console面板&#xff09;是两种最常用的工具&#xff0c;能够帮助开发者有效地捕…

vue2侧边导航栏路由

<template><div><!-- :default-active"$route.path" 和index对应其路径 --><el-menu:default-active"active"class"el-menu-vertical-demo"background-color"#545c64"text-color"#fff"active-text-col…

时代变迁对传统机器人等方向课程的巨大撕裂

2020年之后&#xff0c;全面转型新质课程规划&#xff0c;传统课程规划全部转为经验。 农耕-代表性生产关系-封建分配制度主要生产力-人力工业-代表性生产关系-资本分配制度工业分为机械时代&#xff0c;电气时代&#xff0c;信息时代&#xff1b;主要生产力-人力转为人脑&…

JVM类加载过程-Loading

一、Class对象的生命周期 .class文件是如何加载到内存中:.class文件是ClassLoader通过IO将文件读到内存,再通过双亲委派的模式进行Loading,再Linking、以及Initializing,代码调用等一系列操作后,进行GC,组成完整的生命周期; 二、双亲委派模式(Loading的过程): 1、类…

BERT--公认的里程碑

前言 如果说&#xff0c;让我选Transformer架构的哪个模型最深入人心&#xff0c;我将毫不犹豫的选择BERT&#xff01; BERT 的意义在于&#xff0c;从大量无标记的数据集中训练得到的深度模型&#xff0c;可以限制提高各项自然语言处理任务的准确率。 BERT 在当时&#xff0…

<项目代码>YOLOv8 瞳孔识别<目标检测>

YOLOv8是一种单阶段&#xff08;one-stage&#xff09;检测算法&#xff0c;它将目标检测问题转化为一个回归问题&#xff0c;能够在一次前向传播过程中同时完成目标的分类和定位任务。相较于两阶段检测算法&#xff08;如Faster R-CNN&#xff09;&#xff0c;YOLOv8具有更高的…

每日OJ题_牛客_天使果冻_递推_C++_Java

目录 牛客_天使果冻_递推 题目解析 C代码 Java代码 牛客_天使果冻_递推 天使果冻 描述&#xff1a; 有 n 个果冻排成一排。第 i 个果冻的美味度是 ai。 天使非常喜欢吃果冻&#xff0c;但她想把最好吃的果冻留到最后收藏。天使想知道前 x个果冻中&#xff0c;美味…

果韵 2.0.1| 听歌神器,双端支持,支持下载歌曲和歌词

果韵是一款支持Windows和安卓双端的音乐播放器&#xff0c;支持自定义音源&#xff0c;界面简洁。用户可以通过缓存下载歌曲和歌词。为了使用这些功能&#xff0c;需要先进行音源导入。通过设置中的存储设置&#xff0c;将缓存文件夹移动到download目录下&#xff0c;之后缓存的…

Allegro从.brd文件中导出器件ball map

Step 1&#xff08;可选&#xff09;&#xff1a;设置网络颜色 Step2&#xff1a;File->Export->Symbol Spreadsheet\ Step3&#xff1a;Primary text选择Net Name Step 4&#xff1a;在.brd所有文件夹下生成一个ball map文件&#xff0c;其中网络颜色与Step 1一致。ba…

Docker入门之Windows安装Docker初体验

在之前我们认识了docker的容器&#xff0c;了解了docker的相关概念&#xff1a;镜像&#xff0c;容器&#xff0c;仓库&#xff1a;面试官让你介绍一下docker&#xff0c;别再说不知道了 之后又带大家动手体验了一下docker从零开始玩转 Docker&#xff1a;一站式入门指南&#…

家庭网络常识:猫与路由器

这张图大家应该不陌生——以前家庭网络的连接方式。 图1 家庭网络连接示意图 来说说猫/光猫&#xff1a; 先看看两者的图片。 图2 猫 图3 光猫 这个东西因为英文叫“modem”&#xff0c;类似中文的“猫”&#xff0c;所以简称“猫”。 猫和光猫的区别就是&#xff0c;一…

三种复制只有阅读权限的飞书网络文档的方法

大家都知道&#xff0c;飞书是一款功能强大的在线协作工具&#xff0c;可以帮助团队更高效地协作和沟通。越来越多的资料都在使用飞书文档&#xff0c;在使用飞书的过程中&#xff0c;发现很多文档没有复制权限&#xff0c;如果想要摘抄笔记&#xff0c;只能一个字一个字地敲出…

elasticsearch的倒排索引是什么?

大家好&#xff0c;我是锋哥。今天分享关于【elasticsearch的倒排索引是什么&#xff1f;】面试题。希望对大家有帮助&#xff1b; elasticsearch的倒排索引是什么&#xff1f; 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 倒排索引&#xff08;Inverted Index&a…

基于Java Springboot甘肃旅游管理系统

一、作品包含 源码数据库设计文档万字PPT全套环境和工具资源部署教程 二、项目技术 前端技术&#xff1a;Html、Css、Js、Vue、Element-ui 数据库&#xff1a;MySQL 后端技术&#xff1a;Java、Spring Boot、MyBatis 三、运行环境 开发工具&#xff1a;IDEA/eclipse 数据…

uniApp项目运行到鸿蒙手机,应用图标一直是H,应用名一直是HBuilder问题

项目运行到鸿蒙手机&#xff0c;应用图标一直是H,应用名一直是HBuilder问题 应用运行到鸿蒙手机和鸿蒙模拟器&#xff0c;应用图标一直是H,应用名一直是HBuilder&#xff0c;在自动生成的harmony-configs文件夹下也没有配置的文件&#xff0c; 这时候需要你将DevEco Studio 下…

Python3.11.9+selenium,获取图片验证码以及输入验证码数字

Python3.11.9+selenium,获取图片验证码以及输入验证码数字 1、遇到问题:登录或修改密码需要验证码 2、解决办法: 2.1、安装ddddocr pip install ddddocr 2.2、解析验证码函数 import ddddocr def get_capcha_text():#获取验证码图片ele_pic = driver.find_element(By.XPAT…

中伟视界:AI智能分析算法如何针对非煤矿山的特定需求,提供定制化的安全生产解决方案

非煤矿山智能化改造&#xff0c;除了政策文件&#xff0c;上级监管单位需要安装的AI智能分析算法功能之外的&#xff0c;矿方真正关心的&#xff0c;能解决矿方安全生产隐患的AI智能分析算法功能有哪些呢&#xff1f; 经过与矿方的现场交流沟通&#xff0c;收集第一现场人员对安…