Solved

SQL: Convert Varchar to Int

Posted on 2008-10-31
11
1,672 Views
Last Modified: 2010-04-21
I am trying to use CAST to convert a Varchar to an Integer

Update Table1
set field1 = (select CAST(field2 as INT) from table2 where......

The values in field 2 are all numeric with 2 decimals. The error reads: " Syntax error converting the varchar value of '1,456.88' to a column of data type int.

based on other posts, I am assuming it is the comma it dosent like. But I am guessing, and not sure how to go about removing it in the process.

Thanks,

0
Comment
Question by:JDCam
  • 5
  • 3
  • 3
11 Comments
 
LVL 39

Expert Comment

by:BrandonGalderisi
ID: 22851616
Try:


select cast(floor(cast('1,456.88' as money))as int)

Without the floor, it will round to the nearest.

1456.49 = 1456
1456.50 = 1557


so

Update t1
set field1 = cast(floor(cast(t2.field2 as money))as int)
from table1 t1
join Table2 t2
on Table1.WHAT  = table2.WHAT
where
0
 
LVL 22

Expert Comment

by:dportas
ID: 22851813
CAST(REPLACE(field2,',','') as INT)
0
 
LVL 39

Expert Comment

by:BrandonGalderisi
ID: 22851859
DOH!

Sometimes the solution is so simple.
0
Windows Server 2016: All you need to know

Learn about Hyper-V features that increase functionality and usability of Microsoft Windows Server 2016. Also, throughout this eBook, you’ll find some basic PowerShell examples that will help you leverage the scripts in your environments!

 

Author Comment

by:JDCam
ID: 22851915
I typed exactly what you have, even cut and paste to be sure (changed the field name of course) but the same error persists

 (SELECT     CAST(REPLACE(User5, ',', '') AS INT) AS Expr1
                            FROM          SKUInfo
                            WHERE    

when i run it, SQL Mgt Studio adjusts some spacing etc, and adds 'AS Expr1' , but the error is the same
0
 
LVL 22

Expert Comment

by:dportas
ID: 22852049
Then I guess you have some other non-numerics in the table that are causing a problem.

Try the following query to find them:

SELECT User5
FROM SKUInfo
WHERE User5 LIKE '%[^0-9.]%';
0
 

Author Comment

by:JDCam
ID: 22852098
Hmm.. every row was returned.
all appear to have the same format as  
1,096.88

0
 
LVL 22

Accepted Solution

by:
dportas earned 250 total points
ID: 22852136
I forgot to include , in the LIKE expression:

SELECT User5
FROM SKUInfo
WHERE User5 LIKE '%[^0-9.,]%';

The point of this is to return any rows that contain non-numeric characters.
0
 

Author Comment

by:JDCam
ID: 22852156
Ok, Now no records are returned.
0
 

Author Comment

by:JDCam
ID: 22852268
Although the error message gripes about converting to INT, I just noticed in the database, the destination field is type 'Dimension:float'
Does this change anything??
0
 
LVL 39

Assisted Solution

by:BrandonGalderisi
BrandonGalderisi earned 250 total points
ID: 22852312
It changes that you don't want to cast to an int anymore, but rather a float.

using dportas' simpler code, the whole thing would look like...
Update t1
set field1 = cast(replace(t2.field2,',','') as float)
from table1 t1
join Table2 t2
on Table1.WHAT  = table2.WHAT
where....

Open in new window

0
 

Author Closing Comment

by:JDCam
ID: 31512143
Thanks Guys,
I split the points between you on this one
0

Featured Post

Master Your Team's Linux and Cloud Stack

Come see why top tech companies like Mailchimp and Media Temple use Linux Academy to build their employee training programs.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
SQL date incremented 11 31
This query failed in sql 2014 5 32
Inserting oldest record into new table. 5 25
Sql server get data from a usp to use in a usp 5 16
Occasionally there is a need to clean table columns, especially if you have inherited legacy data. There are obviously many ways to accomplish that, including elaborate UPDATE queries with anywhere from one to numerous REPLACE functions (even within…
This article explains how to reset the password of the sa account on a Microsoft SQL Server.  The steps in this article work in SQL 2005, 2008, 2008 R2, 2012, 2014 and 2016.
Viewers will learn how to use the INSERT statement to insert data into their tables. It will also introduce the NULL statement, to show them what happens when no value is giving for any given column.
Viewers will learn how to use the UPDATE and DELETE statements to change or remove existing data from their tables. Make a table: Update a specific column given a specific row using the UPDATE statement: Remove a set of values using the DELETE s…

803 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