久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

將列作為參數傳遞給 SQL Server 中的 dateadd

Pass a column as parameter to dateadd in SQL Server(將列作為參數傳遞給 SQL Server 中的 dateadd)
本文介紹了將列作為參數傳遞給 SQL Server 中的 dateadd的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我想將一列 UTC 時間轉換為本地時間.

我的數據如下所示:

time_utc TZID 時區------------------------------------------------2014-02-27 12:00:39.0 美國/多倫多-52013-05-21 09:35:30.0 America/Goose_Bay -42015-01-08 06:58:58.0 美國/克雷斯頓 -7

我知道使用

select *, DATEADD(hour, 5,time_utc)來自 mytable

將向 time_utc 列添加 5 小時.

但是,如您所見,我有一個可變時區列.

如何將此變量傳遞給 dateadd 函數?

我嘗試了以下 2 個命令,但它們不起作用:

嘗試 #1:

select *, DATEADD(hour, timezone, time_utc)來自 mytable

嘗試 #2:

select *, DATEADD(hour, (select timezone from mytable), time_utc)來自 mytable

兩者都拋出這個錯誤:

<塊引用>

參數數據類型 varchar 對 dateadd 函數的參數 2 無效.[SQL 狀態=S0001,數據庫錯誤代碼=8116]

對于時區的十進制值,例如 -3.5,這將如何工作?

謝謝

解決方案

如何將此變量傳遞給 datetime 函數?

只需在函數調用中引用列:

select *, DATEADD(hour, timezone, time_utc)來自 mytable

<塊引用>

對于時區的十進制值,例如 -3.5,這將如何工作?

DATEADD 的數字"參數采用整數,因此您必須更改為分鐘并縮放小時偏移量.由于您的 timezone 列顯然是一個 varchar 列,因此也將其轉換為十進制值:

select *, DATEADD(minute, cast(timezone as decimal(4,2)) * 60 , time_utc)來自 mytable

I want to convert a column of UTC time to local time.

My data looks like this:

time_utc                TZID            timezone
------------------------------------------------
2014-02-27 12:00:39.0   America/Toronto     -5
2013-05-21 09:35:30.0   America/Goose_Bay   -4
2015-01-08 06:58:58.0   America/Creston     -7

I know that using

select *, DATEADD(hour, 5,time_utc)
from mytable

will add 5 hours to column time_utc.

However, as you can see, I have a variable time zone column.

How can I pass this variable to the dateadd function?

I tried the following 2 commands but they don't work:

Attempt #1:

select *, DATEADD(hour, timezone, time_utc)
from mytable

Attempt #2:

select *, DATEADD(hour, (select timezone from mytable), time_utc)
from mytable

Both throws this error:

Argument data type varchar is invalid for argument 2 of dateadd function. [SQL State=S0001, DB Errorcode=8116]

For decimal values of timezone, for instance -3.5, how would this work?

Thanks

解決方案

How can I pass this variable to datetime function?

Just reference the column in the function call:

select *, DATEADD(hour, timezone, time_utc)
from mytable

For decimal values of timezone, for instance -3.5, how would this work?

The "number" parameter of DATEADD takes an integer, so you'd have to change to minutes and scale the hour offset. Since your timezone colume is apparently a varchar column, convert it to a decimal value as well:

select *, DATEADD(minute, cast(timezone as decimal(4,2)) * 60 , time_utc)
from mytable

這篇關于將列作為參數傳遞給 SQL Server 中的 dateadd的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

Converting Every Child Tags in to a Single Column with multiple Delimiters -SQL Server (3)(將每個子標記轉換為具有多個分隔符的單列-SQL Server (3))
How can I create a view from more than one table?(如何從多個表創建視圖?)
Create calculated value based on calculated value inside previous row(根據前一行內的計算值創建計算值)
How do I stack the first two columns of a table into a single column, but also pair third column with the first column only?(如何將表格的前兩列堆疊成一列,但也僅將第三列與第一列配對?) - IT屋-程序員軟件開發技
Recursive t-sql query(遞歸 t-sql 查詢)
Convert Month Name to Date / Month Number (Combinations of Questions amp; Answers)(將月份名稱轉換為日期/月份編號(問題和答案的組合))
主站蜘蛛池模板: 国内毛片毛片毛片毛片 | 三级av在线 | 欧美一级久久精品 | 国产精品视频一二三区 | av黄色在线| 欧美日韩高清在线观看 | 国产免费一区二区三区最新6 | www.久久 | 免费一级黄色 | 欧美一区2区三区4区公司 | 国内精品久久精品 | 精品一二三区 | 瑟瑟激情| 午夜影院在线观看免费 | 日本aa毛片a级毛片免费观看 | 成人精品国产 | 99免费精品 | 欧美成人精品一区二区三区 | 综合色在线 | 男人的天堂久久 | 国产性网| 亚州毛片 | 夜夜爽99久久国产综合精品女不卡 | 色桃网 | 9色网站 | 超碰超碰 | 亚洲激情在线观看 | 秋霞电影一区二区 | 国产成人免费视频 | 国产精品毛片无码 | 国产精品久久久久久久久久久免费看 | 日韩免费网 | 免费精品 | 亚洲电影在线播放 | 2一3sex性hd| 成人综合视频在线观看 | 精品国产高清一区二区三区 | 亚洲成人精品免费 | 香蕉久久a毛片 | 亚洲成年在线 | www.国产精品 |