January 4, 2005 at 1:30 pm
I used the Data Transformation Service to move a table from Accesss to the SQL Server...what I found is that a Number data type in Access came over as float..which is fine..but the number in access as an example was .33 and it came over to SQL Server as '0'....and any number like .55 came over as 1...so it is rounding...
I am doing some calculations in an sql so as to mimic the results I had in Access, and for some reason the one field I am having a problem with has to do with the above issue..
Any ideas of what I can do to resolve this...maybe a proper data type???
Thank you.
January 4, 2005 at 1:45 pm
Can you post the calculations?
When you say 'proper', what do you mean?
Phil
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
January 4, 2005 at 1:54 pm
Ok...in the Access query I have the following as an expression:
xServiceLevel: IIf(Sum([handled])=0,0,Sum([servicelevel]*[handled])/Sum([handled]))
In SQL I have the following so as to mimic the above:
(CASE Sum(handled) WHEN 0 THEN 0 ELSE 100*Sum(servicelevel*handled)/Sum(handled) END) AS [xServiceLevel]
The result in access as an example is .6663369
The result in SQL is .7069717
When I look at the servicelevel field in Access they are like .33, .75, .25....etc.
When I look at the field in SQL Server it is 1 or 0...
I hope that I am explaining myself..
Thank you.
January 4, 2005 at 2:59 pm
What I mean by proper is accurate....
I think that I may have confused some...I am sure that someone has come across this problem (if it is a problem)...
Basically, the numbers appearing on the SQL Server are different than those that appear in a similar table within Access...I have narrowed it down to that...
Any and all suggestions will be very helpful!
Thank you.
January 4, 2005 at 3:33 pm
Can you tell us what the datatypes are in both SQL Server and Access?
I wasn't born stupid - I had to study.
January 4, 2005 at 4:04 pm
Yep, if the datatypes of 'Handled' and 'ServiceLevel' are integer, then the result of your calculation will be an integer.
You could try the following, to force the result to be a float:
(CASE Sum(handled) WHEN 0 THEN 0 ELSE 100*Sum(servicelevel*handled)/cast(Sum(handled) as float)
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
January 5, 2005 at 6:14 am
The datatypes for the fields in question are as follows:
System - Fields - Datatype
Access - ServiceLevel - Number
Access - Handled - Number
SQL Server - ServiceLevel - int
SQL Server - Handled - int
I used the suggestion by Phil Parkin, and it did not adjust the value...it just changed it to a float...
As I stated, it has to do with the ServiceLevel field...I mean I am no expert, but when this field is viewed in Access you can see the decimal placement such as .33 or .75...but when you view it in SQL Server...whether the datatype is int or float...it still come out as either 0 or 1..
I hope that this can help you to help me!
January 5, 2005 at 7:07 am
Once you change it to a float, you will need to load the data from Access again.
January 5, 2005 at 7:18 am
I do not understand what you mean....
Could you explain a little more...I am a newbie at most of this!
Thank you.
January 5, 2005 at 3:29 pm
I think I see now, (said the blind man). A number in Access is not the same as an integer. I do not know what the precision is in Access, but it must handle numbers out to some decimal place.
Hence, once your data came into SQL and was converted to an integer, it lost that precision. That is why you were no longer seeing the 0.33, but rather just 0. (Actually, that is why I asked the question about the datatypes).
Converting an integer to a float does not gain back that precision. Once you brought the data into SQL and cast it as an integer, the precision was lost. Robert Stewart is absolutely correct in stating that you need reload the data from Access again. The data from Access needs to be loaded into a SQL table already defined with a float, (or numeric(5,3) or decimal(25,5)) column.
You should be able to retain your precision that way. I hope that helps...
I wasn't born stupid - I had to study.
January 6, 2005 at 6:30 am
Farrell,
Correct. You should not use the upsizing wizard to load data. Sometimes you can have issues with the datatypes it translates to. Once the corrections are made, if any, then you can use DTS or Access queries to transfer the data from Access to SQL Server.
When you look at the Access side of it, there is a 2-setp process for defining numbers. The first is numeric, the second is integer, long integer, single, double, decimal, etc. The second step defines the "precision" in Access. Access calls it "Field Size."
January 6, 2005 at 7:55 am
Thank you all very much...for your assistance!
Everything is working fine.
This is a great forum, and I am learning alot from the active dialog in here...keep it up!
Viewing 12 posts - 1 through 11 (of 11 total)
You must be logged in to reply to this topic. Login to reply