當(dāng)前位置:首頁 >  站長 >  數(shù)據(jù)庫 >  正文

解析SQL Server中datetimeset轉(zhuǎn)換datetime類型問題

 2021-01-05 16:48  來源: 腳本之家   我來投稿 撤稿糾錯

  域名預(yù)訂/競價,好“米”不錯過

這篇文章主要介紹了SQL Server中datetimeset轉(zhuǎn)換datetime類型問題淺析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

在SQL Server中,數(shù)據(jù)類型datetimeoffset轉(zhuǎn)換為datetime類型或datetime2類型時需要特別注意,有可能一不小心你可能會碰到下面這種情況。下面我們構(gòu)造一個簡單案例,模擬一下你們可能遇到的情況。

CREATE TABLE TEST
(
ID INT IDENTITY(1,1)
,CREATE_TIME DATETIME
,CONSTRAINT PK_TEST PRIMARY KEY(ID)

);
GO

INSERT INTO TEST(CREATE_TIME)
SELECT '2020-10-03 11:10:36' UNION ALL
SELECT '2020-10-03 11:11:36' UNION ALL
SELECT '2020-10-03 11:12:36' UNION ALL
SELECT '2020-10-03 11:13:36';

DECLARE @p1 DATETIMEOFFSET;
SET @p1='2020-10-03 11:12:36.9200000 +08:00'
SELECT * FROM dbo.TEST
WHERE CREATE_TIME <=@p1;

如下截圖所示,你會發(fā)現(xiàn)這個查詢SQL查不到任何記錄。相信以前對數(shù)據(jù)類型datetimeoffset不太熟悉的人會對這個現(xiàn)象一臉懵逼......

那么我們通過下面例子來給你簡單介紹一下,datetimeoffset通過不同方式轉(zhuǎn)換為datetime有啥區(qū)別,具體腳本如下:

DECLARE @p1 DATETIMEOFFSET;
DECLARE @p2 DATETIME;
DECLARE @p3 DATETIME2;

SET @p1='2020-10-03 11:10:36.9200000 +08:00'
SET @p2=@p1;
SET @p3=@p1;

SELECT @p1 AS '@p1'
,@p2 AS '@p2'
,CAST(@p1 AS DATETIME) AS 'datetimeoffset_cast_datetime'
,CONVERT(DATETIME, @p1, 1) AS 'datetimeoffset_convert_datetime'

如下截圖所示,通過CONVERT函數(shù)將datetiemoffset轉(zhuǎn)換為datetime,你會發(fā)現(xiàn)上面這種方式丟失了時區(qū)信息,它將datetimeoffset轉(zhuǎn)換為了UTC時間了。官方文檔介紹:轉(zhuǎn)換到datetime 時,會復(fù)制日期和時間值,時區(qū)被截斷。

注意:datetiemoffset轉(zhuǎn)換為datetime2也是同樣的情況,這里不做贅述了。

所以,最開始,我們構(gòu)造的案例中,出現(xiàn)那種現(xiàn)象是因為@p1和CREATE_TIME比較時,發(fā)生了隱式轉(zhuǎn)換,datetiemoffset轉(zhuǎn)換為datetime,而且轉(zhuǎn)換過程中時區(qū)丟失了,此時的SQL實際等價于CREATE_TIME <='2020-10-03 03:10:36.920'了,那么怎么解決這個問題,如果在不改變數(shù)據(jù)類型的情況下,有什么解決方案解決這個問題呢?

方案1:使用CAST轉(zhuǎn)換函數(shù)。

DECLARE @p1 DATETIMEOFFSET;
SET @p1='2020-10-03 11:12:36.9200000 +08:00'
SELECT * FROM dbo.TEST
WHERE CREATE_TIME <=CAST(@p1 AS DATETIME)

方案2:CONVERT函數(shù)中指定date_style為0 ,可以保留時區(qū)信息。

DECLARE @p1 DATETIMEOFFSET;
SET @p1='2020-10-03 11:12:36.9200000 +08:00'
SELECT * FROM dbo.TEST
WHERE CREATE_TIME <=CONVERT(DATETIME, @p1, 0)

下面例子演示對比,有興趣的話,自行執(zhí)行SQL后對比觀察

DECLARE @p1 DATETIMEOFFSET;
DECLARE @p2 DATETIME;
DECLARE @p3 DATETIME2;

SET @p1='2020-10-03 11:10:36.9200000 +08:00'
SET @p2=@p1;
SET @p3=@p1;

SELECT @p1 AS '@p1'
,@p2 AS '@p2'
,CAST(@p1 AS DATETIME) AS 'datetimeoffset_cast_datetime'
,CONVERT(DATETIME, @p1, 0) AS 'datetimeoffset_convert_datetime'
,CONVERT(DATETIME, @p1, 1) AS 'datetimeoffset_convert_datetime1'

方案3:SQL Server 2016(13.x)或以后的版本可以使用下面方案。

注意之前的SQL Server版本不支持這種寫法.

DECLARE @p1 DATETIMEOFFSET;
SET @p1='2020-10-03 11:12:36.9200000 +08:00'
SELECT * FROM dbo.TEST
WHERE CREATE_TIME <= CONVERT(DATETIME, @p1 AT TIME ZONE 'UTC' AT TIME ZONE 'China Standard Time')

到此這篇關(guān)于SQL Server中datetimeset轉(zhuǎn)換datetime類型問題淺析的文章就介紹到這了,更多相關(guān)SQL Server中datetimeset轉(zhuǎn)換datetime類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

來源:腳本之家

鏈接:https://www.jb51.net/article/203041.htm

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 yy@haotui.cn 举报,一经查实,本站将立刻删除。

申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點子。點擊此處,共同探討創(chuàng)業(yè)新機遇!

相關(guān)標(biāo)簽
sqlserver

相關(guān)文章

創(chuàng)業(yè)項目推薦

    熱門排行

    信息推薦