Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win

x
?
Solved

Arithmetic overflow error converting expression to data type smalldatetime!!!

Posted on 2006-06-12
2
Medium Priority
?
1,955 Views
Last Modified: 2012-06-22
Hi! i have a table that has a column with dates that where stored in a decimal type field! ... i've converted that columnn to nvarchar(50) and then parsed the the dates from '20040225' to
'2004-02-25' . That went ok. (the dates with the '20040225' where in a decimal type field...go figure!) ... but now ... after parsing the dates to the '2004-02-25' format, when i try to change the column from nvarchar(50) to smalldatetime i get the error: Arithmetic overflow error converting expression to data type smalldatetime.

I know this has something to do with some wrong date around somewhere. How can i find the wrong dates in my table? is there a query to do it? i know there is! ... please help!
0
Comment
Question by:xjpmauricio
[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
2 Comments
 
LVL 143

Accepted Solution

by:
Guy Hengel [angelIII / a3] earned 2000 total points
ID: 16883864
you should create a additional column (with datetime), and update it:

update yourtable
  set new_field=  convert(datetime, yourfield, 120)

if that gives the same error, you need to identify the rows.
I would load the field into a test table:

create table test_date_values ( id int, year_value varchar(4), month_value varchar(2), day_value varchar(2))
insert into test_date_values select id, substring(yourfield, 1,4), substring(yourfield, 6,2), substring(yourfield, 9,2) from yourtable

and how, check the validity of the dates...
0
 
LVL 1

Author Comment

by:xjpmauricio
ID: 16883918
--FIND INVALID DATES

create table test_date_values ( id int, year_value varchar(4), month_value varchar(2), day_value varchar(2))
insert into test_date_values select id,
substring(DATA_SITUACAO, 1,4), substring(DATA_SITUACAO, 6,2), substring(DATA_SITUACAO, 9,2) from FARQ_007D

select * from test_date_values where month_value  > 31

...the solution whas so simple that i think i'm such a dum bustard!!! god!....

thanks a lot!...
0

Featured Post

Learn Veeam advantages over legacy backup

Every day, more and more legacy backup customers switch to Veeam. Technologies designed for the client-server era cannot restore any IT service running in the hybrid cloud within seconds. Learn top Veeam advantages over legacy backup and get Veeam for the price of your renewal

Question has a verified solution.

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

For both online and offline retail, the cross-channel business is the most recent pattern in the B2C trade space.
Windocks is an independent port of Docker's open source to Windows.   This article introduces the use of SQL Server in containers, with integrated support of SQL Server database cloning.
Using examples as well as descriptions, and references to Books Online, show the documentation available for date manipulation functions and by using a select few of these functions, show how date based data can be manipulated with these functions.
Viewers will learn how the fundamental information of how to create a table.

609 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