MySQL數據庫時間計算的用法

今天給大家分享如何通過MySQL內置函數實現時間的轉換和計算,在工作當中,測試人員經常需要查詢數據庫表的日期時間,但發現開發人員存入數據庫表的形式都是時間戳形式,不利于測試人員查看,測試人員只能利用工具對時間戳進行轉換,才能直觀查看。但這樣會增加測試人員的效率,那么可巧妙的使用MySQL內置函數,便可以輕松解決這個問題,以及通過內置函數對時間進行加減計算,便可以提高工作的效率。

(一)時間戳和日期時間的轉換

應用場景

用于獲取當前的日期時間、時間戳,以及時間戳和日期時間的轉換

# 1.獲取當前日期時間
select now();# 2.獲取當前時間戳
select unix_timestamp();# 3.時間戳轉成日期時間
select from_unixtime(1688264330);# 4.日期時間轉成時間戳
select unix_timestamp('2023-07-02 00:00:00');

(二)日期時間的加減計算

1.date_add()

說明:date_add():為當前日期增加一個時間間隔

用法:此函數可用于計算距離當前日期一個月之后的日期

語法格式:DATE_ADD(date,interval expr type)

date:指定的時間日期

interval:固定寫法

expr:所增加的時間間隔

type:時間間隔的單位,包括:秒、分鐘、小時、天、星期、月、季、年等

# 加1天
select now(),date_add(now(), interval 1 day);
# 加1小時
select now(),date_add(now(), interval 1 hour);
# 加1分鐘
select now(),date_add(now(), interval 1 minute );
# 加1秒
select now(),date_add(now(), interval 1 second );# 加1周
select now(),date_add(now(), interval 1 week);
# 加1個月
select now(),date_add(now(), interval 1 month);
# 加1季度
select now(),date_add(now(), interval 1 quarter );
# 加1年
select now(),date_add(now(), interval 1 year );

2. date_sub()

說明:date_sub():為當前日期減去一個時間間隔

用法:此函數可用于計算距離當前日期一個月之前的日期

語法格式:DATE_SUB(date,interval expr type)

date:指定的時間日期

interval:固定寫法

expr:所減去的時間間隔

type:時間間隔的單位,包括:秒、分鐘、小時、天、星期、月、季、年等

# 減1天
select date_sub(now(), interval 1 day);
# 減1小時
select date_sub(now(), interval 1 hour);
# 減1分鐘
select now(),date_sub(now(), interval 1 minute );
# 減1秒
select now(),date_sub(now(), interval 1 second );# 減1周
select now(),date_sub(now(), interval 1 week);
# 減1個月
select now(),date_sub(now(), interval 1 month);
# 減1季度
select now(),date_sub(now(), interval 1 quarter );
# 減1年
select now(),date_sub(now(), interval 1 year );

(三)兩個日期時間的間隔計算

方式一

內置函數:TimeStampDiff(間隔類型,前一個日期,后一個日期);

間隔類型:second:秒,minute:分鐘,hour:小時,day:天,week:周,month:月,quarter:季度,year:年

前一個日期:日期時間格式

后一個日期:日期時間格式

應用場景:用于計算兩個日期時間的間隔時間

# 計算間隔的秒
select timestampdiff(second , '2023-07-05 00:00:00',now());# 另外可用函數sec_to_time()將秒換算成:時:分:秒格式
select sec_to_time(1500);#計算間隔的分鐘
select timestampdiff(minute , '2023-07-05 00:00:00',now());# 計算間隔的小時
select timestampdiff(hour , '2023-07-05 00:00:00',now());# 計算間隔的天
select timestampdiff(day, '2023-07-05 00:00:00',now());# 另外可通過兩個日期的時間戳相減,得到間隔的時間戳形式
select unix_timestamp()- unix_timestamp('2023-07-05');

方式二

應用場景:直接將兩個日期時間相減,得到的間隔時間為:XX天XX小時XX分鐘XX秒

# 將時間間隔換算成XX天XX小時XX分鐘XX秒
# 1.通過timestampdiff()函數計算兩個日期所間隔的秒數
# 2.然后通過floor(): 返回一個小于或等于X的最大整數,向下取整
# 3.在使用convert()函數分別將秒數換算成:天、小時、分鐘、秒,得到結果selectconvert(floor(timestampdiff(second , '2023-07-05 00:00:00', now())/(3600*24)),char) '天',convert(floor(timestampdiff(second , '2023-07-05', now())%(3600*24)/3600),char) '小時',convert(floor(timestampdiff(second , '2023-07-05', now())%3600/60),char) '分',convert(timestampdiff(second , '2023-07-05', now())%60,char) '秒';

查詢結果

圖片

最后感謝每一個認真閱讀我文章的人,禮尚往來總是要有的,雖然不是什么很值錢的東西,如果你用得到的話可以直接拿走:

這些資料,對于【軟件測試】的朋友來說應該是最全面最完整的備戰倉庫,這個倉庫也陪伴上萬個測試工程師們走過最艱難的路程,希望也能幫助到你!?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/161758.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/161758.shtml
英文地址,請注明出處:http://en.pswp.cn/news/161758.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【 順序表經典算法—移除元素和合并兩個有序數組】

提示:文章寫完后,目錄可以自動生成,如何生成可參考右邊的幫助文檔 目錄 前言 經典算法OJ題1: 移除元素 解法一、逐個判斷 解法二、雙指針覆蓋 經典算法OJ題2: 合并兩個有序數組 OJ題分為兩個類型: 總結 前言…

MAX/MSP SDK學習07:list傳遞

實現自定義Obejct,要求將傳入的一組數據100后傳出。 #include "ext.h" #include "ext_obex.h" typedef struct _listTrans {t_object ob;void* outLet;t_atom* fArr;long listNum;} t_listTrans;void* listTrans_new(t_symbol* s, long arg…

14.Python 模塊

目錄 1. 使用模塊2. 使用包3. 常用模塊3.1 日期和時間3.2 偽隨機數3.3 摘要算法3.4 JSON 處理3.5 圖像處理 模塊是Python用來組織代碼的一種方法,包是Python用來組織模塊的一種方法。 1. 使用模塊 Python 把能夠相互包含,且有組織的代碼段稱為模塊&…

.NET面試題1

1.什么是C#? C#(讀作"C sharp")是一種通用的、面向對象的編程語言,由Microsoft開發。它是一種靜態類型語言,支持強類型檢查和面向對象編程(OOP)的概念。C#主要用于開發Windows應用程序…

Bug等級劃分

Bug是指在程序或系統中存在的錯誤、缺陷或異常,是由于編碼錯誤、設計問題、邏輯錯誤或其他因素導致的。 常見的Bug分類方法 功能性Bug與軟件的功能有關,軟件無法正常工作、功能與需求不符或功能執行不正確。 用戶界面Bug與軟件的用戶界面有關&#xff…

Unity中Shader雙向反射分布函數BRDF

文章目錄 前言一、渲染方程二、什么是BxDF1、BSSRDF2、BRDF3、BTDF4、BSDF 三、迪士尼原則的BRDF四、迪士尼原則的BRDF的參數五、在Unity中看一下默認Shader的這些參數六、在這里記錄一下使用 Blender 和 SubstancePainter 的流程1、在Blender中導出模型為 .obj 格式2、在Subst…

Android WMS—— Surace管理 (二十)

WMS 負責創建 Surface 以及對 Surface 的擺放工作,之后將 Surface 提交給SurfaceFlinger 進行合并。在 App 層也創建了一個 Surface 對象,但是那個是空對象,用于 WMS 的填充。 一、Surface的創建 首先 APP 層在 ViewRootImpl 的 relayoutWindow() 方法中發起創建任務。 1、…

Go 實現網絡代理

使用 Go 語言開發網絡代理服務可以通過以下步驟完成。這里,我們將使用 golang.org/x/net/proxy 包來創建一個簡單的 SOCKS5 代理服務作為示例。 步驟 1. 安裝 golang.org/x/net/proxy 包 使用以下命令安裝 golang.org/x/net 包,該包包含 proxy 子包&am…

天軟特色因子看板 (2023.11 第12期)

該因子看板跟蹤天軟特色因子A05006(近一月單筆流入流出金額之比(%),該因子為近一個月單筆流入流出金額之比(%)均值因子,用以刻畫在 市場日內分時成交中流入、流出成交金額的差異性特點,發掘市場主力資金的作用機制。 今日為該因子跟蹤第12期&…

expect腳本在自動化部署中的具體應用案例

#expect腳本在自動化部署中的具體應用 expect腳本是一個非常好的交互式應用腳本,在自動化部署中,可以使用這個腳本來實現全自動的自動化部署。下面是一些具體的應用案例。 場景一:自動安裝mysql 可以使用expect腳本來實現mysql自動安裝&…

Windows平臺Unity下實現camera場景推送RTMP|輕量級RTSP服務|實時錄像

技術背景 我們在對接Unity平臺camera場景采集的時候,除了常規的RTMP推送、錄像外,還有一些開發者,需要能實現輕量級RTSP服務,對外提供個拉流的RTSP URL。 目前我們在Windows平臺Unity下數據源可采集到以下部分: 采集…

@PostConstruct雖好,請勿亂用

1.問題說明 在日常的業務開發中,有時會利用PostConstruct在容器啟動時執行一些任務。例如: PostConstruct public void init(){System.out.println("service 初始化..............."); }一般情況這沒什么問題,但最近一個同事在做…

ui5使用echart

相關的代碼已經發布到github上。 展示下相關的實現功能 1、柱狀圖-1 2、柱狀圖-2 3.折線圖 4.餅狀圖 如何使用: 使用git clone項目到本地 git clone https://github.com/linhuang0405/com.joker.Zechart找到index.html。在vscode里右鍵選擇Open with Live Serve…

1

【任務 1】私有云服務搭建[10 分] 【題目 1】基礎環境配置[0.5 分] 【題目 2】Yum 源配置[0.5 分] 【題目 3】配置無秘鑰 ssh[0.5 分] 【題目 4】基礎安裝[0.5 分] 【題目 5】數據庫安裝與調優[0.5 分] 【題目 6】Keystone 服務安裝與使用[0.5 分] 【題目 7】Glance 安裝與使用…

BLE通用廣播包

文章目錄 1、藍牙廣播數據格式2、掃描響應數據 1、藍牙廣播數據格式 藍牙廣播包的最大長度是37個字節,其中設備地址占用了6個字節,只有31個字節是可用的。這31個可用的字節又按照一定的格式來組織,被分割為n個AD Structure。如下圖所示&…

npm命令

node -v --查看版本 npm install --安裝npm npm config get registry --查看npm當前鏡像 npm config set registry https://registry.npmmirror.com --設置淘寶鏡像 npm版本管理工具

VS Code 如何搭建C/C++環境

目錄 一、VS Code是什么? 二、VS Code下載和安裝 2.1下載 2.2安裝 2.3環境介紹 三、Vs Code配置C/C環境 3.1下載和配置MinGW-w64編譯器套件 3.1.1下載 3.1.2配置 一、VS Code是什么? 跨平臺,免費且開源的現代輕量級代碼編輯器 Vis…

【MATLAB源碼-第85期】基于farrow結構的濾波器仿真,截止頻率等參數可調。

操作環境: MATLAB 2022a 1、算法描述 Farrow結構是一種用于實現可變數字濾波器的方法,尤其適用于數字信號處理中的采樣率轉換和時變濾波。它通過多項式近似來實現對濾波器系數的平滑變化,使得濾波器具有可變的群延時或其他參數。 Farrow結…

mysql中數據是如何被用B+樹查詢到的

innoDB是按照頁為單位讀寫的 那頁中有很多行數據,是怎么執行查詢的呢,首先我們肯定,是以單向列表形式存儲的,提高了增刪的效率,但是查詢效率低。所以實際上對頁中的行數據進行了優化,能以二分的方式進行查…

Mac Goland無法調試

去github上下載golang的debug工具delve: go-delve/delve?github.com/go-delve/delve/blob/master/Documentation/installation/README.md?編輯 或者: go install github.com/go-delve/delve/cmd/dlvlatest按照他的安裝方式進行安裝,最后會在本地的…