?
Solved

CAST(date_column + time_column as datetime)

Posted on 2016-07-27
8
Medium Priority
?
48 Views
Last Modified: 2016-07-27
Hi guys

Question for you:  What's the fastest way to add a date column and a time column and cast it as a single datetime column?

Example:
Declare @dt date = '20160727', @tm time = '03:30:00'
SELECT CAST( ???? as datetime) 

Open in new window


Thanks in advance.
Jim
0
Comment
Question by:Jim Horn
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
8 Comments
 
LVL 13

Assisted Solution

by:Dustin Saunders
Dustin Saunders earned 1000 total points
ID: 41731778
I use:
SELECT CONVERT(DATETIME, CONVERT(CHAR(8), @dt, 112) 
  + ' ' + CONVERT(CHAR(8), @tm, 108))

Open in new window

0
 
LVL 6

Expert Comment

by:Manuel Marienne-Duchêne
ID: 41731781
CAST(@dt + @tm AS DATETIME) with space in first position in time
0
 
LVL 13

Expert Comment

by:Dustin Saunders
ID: 41731811
But don't you need extra steps to add in the space in time (say if it were from a column)?  [maybe we should add physics to the categories if we're talking about spacetime :P ]

Anyways, I guess if I used it a lot I'd just stick it in a UDF and call that when needed (seems easiest for me though I don't know if there's a more performance efficient way?)

CREATE FUNCTION concatDT (@dt date,@tm time)
RETURNS datetime
AS
BEGIN
RETURN(	SELECT CONVERT(DATETIME, CONVERT(CHAR(8), @dt, 112) 
	+ ' ' + CONVERT(CHAR(8), @tm, 108)))
END

Open in new window

SELECT dbo.concatDT(@dt,@tm)

Open in new window

0
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 69

Accepted Solution

by:
Scott Pletcher earned 1000 total points
ID: 41731997
SELECT CAST(@dt AS datetime) + @tm
0
 
LVL 13

Expert Comment

by:Dustin Saunders
ID: 41732007
I tried:
Declare @dt date = '20160727', @tm time = '03:30:00'
SELECT CAST(@dt AS datetime) + @tm

Open in new window

and got:
Msg 402, Level 16, State 1, Line 2
The data types datetime and time are incompatible in the add operator.


but
Declare @dt date = '20160727', @tm time = '03:30:00'
SELECT CAST(@dt AS datetime) + CAST(@tm AS datetime)

Open in new window


does work and is less code than mine.
0
 
LVL 69

Expert Comment

by:Scott Pletcher
ID: 41732066
I tried:
Declare @dt date = '20160727', @tm time = '03:30:00'
SELECT CAST(@dt AS datetime) + @tm
and got [an error]

Hmm, worked fine for me, at least through SQL 2012.  Maybe that's a later SQL version restriction?  I know they've made some changes in that area.
0
 
LVL 66

Author Closing Comment

by:Jim Horn
ID: 41732074
Thanks guys.  Chose Scott's answer as it was a less expensive option, which works on my 2008R2 box.
0
 
LVL 13

Expert Comment

by:Dustin Saunders
ID: 41732077
Yeah, I agree that's better way.  It's weird that it doesn't run on my SQL test servers (I tried on SQL 2012 SP3 and 2014); so must have appeared somewhere around there, or maybe I angered some vengeful SQL God.

Might be a good note or item to test though, in case you upgrade production SQL versions in the future it might break the query.
0

Featured Post

Free Backup Tool for VMware and Hyper-V

Restore full virtual machine or individual guest files from 19 common file systems directly from the backup file. Schedule VM backups with PowerShell scripts. Set desired time, lean back and let the script to notify you via email upon completion.  

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Ever wondered why sometimes your SQL Server is slow or unresponsive with connections spiking up but by the time you go in, all is well? The following article will show you how to install and configure a SQL job that will send you email alerts includ…
Recently we ran in to an issue while running some SQL jobs where we were trying to process the cubes.  We got an error saying failure stating 'NT SERVICE\SQLSERVERAGENT does not have access to Analysis Services. So this is a way to automate that wit…
Familiarize people with the process of retrieving data from SQL Server using an Access pass-thru query. Microsoft Access is a very powerful client/server development tool. One of the ways that you can retrieve data from a SQL Server is by using a pa…
Viewers will learn how to use the SELECT statement in SQL and will be exposed to the many uses the SELECT statement has.

765 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question