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

x
?
Solved

SQL / xml / real conversion problem

Posted on 2014-01-23
12
Medium Priority
?
345 Views
Last Modified: 2014-02-16
MS SQL Server 2008.

I have a stored procedure that recieves and xml document and uses it to update a table.

I have a line of code:

  [Tumorhojd] = @xmlData.value('(BRUM-registret/OriginalData2012/Tumorhojd)[1]', 'real'),

Open in new window

that updates a REAL column.

It works when the value of Tumorhojd is a number that has a decimal point, but not when it contains a decimal comma.

We are using decimal comma's in our data.

Is there a way to set up the conversion so that decimal comma is accepted?

Thanks
0
Comment
Question by:soozh
[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
  • 5
  • 4
  • 3
12 Comments
 
LVL 16

Expert Comment

by:Surendra Nath
ID: 39803798
you can do this

[Tumorhojd] = CAST(REPLACE(@xmlData.value('(BRUM-registret/OriginalData2012/Tumorhojd)[1]', 'VARCHAR'),',','') AS REAL)

Open in new window

0
 

Author Comment

by:soozh
ID: 39803841
Yes i could do that but i was wondering how i could change the database/server settings to use decimal comma.
0
 
LVL 16

Expert Comment

by:Surendra Nath
ID: 39803933
I believe that cannot be done (atleast upto my knowledge).
0
Get free NFR key for Veeam Availability Suite 9.5

Veeam is happy to provide a free NFR license (1 year, 2 sockets) to all certified IT Pros. The license allows for the non-production use of Veeam Availability Suite v9.5 in your home lab, without any feature limitations. It works for both VMware and Hyper-V environments

 
LVL 75

Accepted Solution

by:
Anthony Perkins earned 2000 total points
ID: 39808105
Something like this perhaps:
[Tumorhojd] = CAST(REPLACE(@xmlData.value('(BRUM-registret/OriginalData2012/Tumorhojd)[1]', 'varchar(20)'), ',', '.') AS real)

Open in new window

Incidentally using real data type is very very rarely a good idea.
0
 

Author Comment

by:soozh
ID: 39808309
ok how would you store "real" data.  By that i mean data with a decimal point(or comma).

And how do countries that use decimal comma (and i Think that is most of Europé) handle this problem?  MS SQL Server must be set up for the "Locale" just like windows can be?
0
 
LVL 16

Expert Comment

by:Surendra Nath
ID: 39808367
decimal points are accepted, but the commas are not accepted as part of real or decimal data types
0
 

Author Comment

by:soozh
ID: 39808379
what i mean is that if i convert a real to a varchar i would expect it to contain a decimal comma in the countries that use decimal comma, and decimal Point in the countries that use decimal Point....

and it should be configurable... that sounds resonable... you cant expect the french to use decimal Point..
0
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 39808796
ok how would you store "real" data.  By that i mean data with a decimal point(or comma).
Both Real and Float are approximate numeric data types and should only be used for scientific or astronomic data.  That is unless you are OK with $10.23 represented as 10.230000001 or 10.2299999991.  You are better off using numeric (or decimal) or money or smallmoney data types to represent decimal values as they are exact.

And how do countries that use decimal comma (and i Think that is most of Europé) handle this problem?  
This is handled at the application level.  SQL Server does not store values with decimal points or decimal commas.
0
 

Author Comment

by:soozh
ID: 39808899
This is handled at the application level.  SQL Server does not store values with decimal points or decimal commas.

I understand..but if i have a stored procedure with this code:

[Tumorhojd] = @xmlData.value('(BRUM-registret/OriginalData2012/Tumorhojd)[1]', 'real' )

i guess the stored procedure is the application - so how do it get it to use decimal comma?
0
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 39809117
Did you see my solution earlier on?
0
 

Author Comment

by:soozh
ID: 39809187
yes but say i am programing in delphi to can convert a string '1,23' to a real number using the standard strToFloat function.

However if my code is run on a server with English settings this would give an error because it expects '1.23'

the StrToFloat function looks at the locale to determine what type of decimal character to use.

Since i am using standard tsql code i would expect the tsql functions to look at the locale and convert decimals and dates accordingly.

So my assumption is that maybe i have the locale set wrong?
0
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 39809333
It is possible.  I don't really know.
0

Featured Post

Enroll in October's Free Course of the Month

Do you work with and analyze data? Enroll in October's Course of the Month for 7+ hours of SQL training, allowing you to quickly and efficiently store or retrieve data. It's free for Premium Members, Team Accounts, and Qualified Experts!

Question has a verified solution.

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

I have written a PowerShell script to "walk" the security structure of each SQL instance to find:         Each Login (Windows or SQL)             * Its Server Roles             * Every database to which the login is mapped             * The associated "Database User" for this …
If you have heard of RFC822 date formats, they can be quite a challenge in SQL Server. RFC822 is an Internet standard format for email message headers, including all dates within those headers. The RFC822 protocols are available in detail at:   ht…
Sometimes it takes a new vantage point, apart from our everyday security practices, to truly see our Active Directory (AD) vulnerabilities. We get used to implementing the same techniques and checking the same areas for a breach. This pattern can re…
Is your data getting by on basic protection measures? In today’s climate of debilitating malware and ransomware—like WannaCry—that may not be enough. You need to establish more than basics, like a recovery plan that protects both data and endpoints.…

650 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