Toon posts:

[Classic ASP] ADO localization probleem

Pagina: 1
Acties:

Onderwerpen


  • _VpS_
  • Registratie: September 2002
  • Laatst online: 14-04 13:50
Ik heb 2 servers waarvan de regional settings identiek zijn. Beide servers draaien op win 2003 met IIS6 en sql server 2000.

Gegeven de volgende legacy code in classic ASP:
Visual Basic:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
set conn=Server.CreateObject("ADODB.Connection")
conn.open "Provider=SQLOLEDB.1;User ID=xxx;Initial Catalog=zzzz;Persist Security Info=True;Password=yyy;Data Source=qqq"
set rs = Server.CreateObject("ADODB.recordset")
Dim c
c = "3,14"

Dim objCommand 
Set objCommand = Server.CreateObject("ADODB.Command")
With objCommand
  .ActiveConnection = conn  
  .CommandType = 1
  .CommandText = "update mytbl set dblvalue=?"        
  .Prepared = True
  .Parameters.Append .CreateParameter("val", 5 , 1, , c)    
  .Execute , , adExecuteNoRecords
End With


Probleem:
  • Op de ene server wordt "3.14" opgeslagen als "3.14" en "3,14" als "314"
  • Op de andere server wordt "3.14" opgeslagen als "314" en "3,14" als "3.14"
Waar komt dit verschil vandaan? Het heeft sowieso te maken met localization settings, maar voor zover ik kan zien zijn ze identiek en bovendien zou localization geen issue moeten zijn met ado parameters?

(bb) || !(bb)


  • RobIII
  • Registratie: December 2001
  • Laatst online: 13:54

RobIII

Admin Devschuur®

^ Romeinse Ⅲ ja!

_VpS_ schreef op maandag 27 juni 2011 @ 16:25:
maar voor zover ik kan zien zijn ze identiek
Heb je toevallig een LCID geset in de ASP pagina's ergens? En zo ja, staat die bij beiden hetzelfde? (Let op, er is een metabase LCID, een page directive LCID, een Session LCID en een Response LCID). Verder zou je, to be sure, even een "select @@language, @@langid" op beide servers los kunnen laten, maar AFAIK is dat niet echt relevant.
_VpS_ schreef op maandag 27 juni 2011 @ 16:25:
en bovendien zou localization geen issue moeten zijn met ado parameters?
Als je een float/double zou passen als parameter niet nee, maar je passed een string...
Je hebt nu:
Visual Basic:
1
2
Dim c
c = "3,14"

Maak daar eens van:
Visual Basic:
1
2
Dim c
c = 3.14

Als je de waardes uit user-input krijg zul je dus even een CDbl, CSng, CCur oid erop los moeten laten. Denk eraan dat deze functies locale-aware zijn en dus afhankelijk van de LCID.

[Voor 45% gewijzigd door RobIII op 27-06-2011 19:07]

There are only two hard problems in distributed systems: 2. Exactly-once delivery 1. Guaranteed order of messages 2. Exactly-once delivery.

Roses are red Violets are blue, Unexpected ‘{‘ on line 32.

Over mij


  • Grijze Vos
  • Registratie: December 2002
  • Laatst online: 29-03 00:00
check ook even de collation van je databases

Op zoek naar een nieuwe collega, .NET webdev, voornamelijk productontwikkeling. DM voor meer info


  • _VpS_
  • Registratie: September 2002
  • Laatst online: 14-04 13:50
Ik was op een zijspoor gezet. Het ligt niet aan de ADO code.

Dit is een zwaar versimpelde versie van de echte code. De productie code draait in een COM+ dll geschreven in VB6. RobIII's comment hielp me op weg.

De LCID in de DLL opgrevraagd: op de ene server is het 1043 en op de andere 1033, ondanks dat de regional settings op beide servers identiek zijn (er wordt overigens nergens expliciet een LCID ingesteld).

Is er een andere setting in windows die hierop van invloed is?

(bb) || !(bb)


  • RobIII
  • Registratie: December 2001
  • Laatst online: 13:54

RobIII

Admin Devschuur®

^ Romeinse Ⅲ ja!

_VpS_ schreef op dinsdag 28 juni 2011 @ 15:25:
Is er een andere setting in windows die hierop van invloed is?
Ben je alle 4(!) locaties waar die LCID kan voorkomen nagelopen?

There are only two hard problems in distributed systems: 2. Exactly-once delivery 1. Guaranteed order of messages 2. Exactly-once delivery.

Roses are red Violets are blue, Unexpected ‘{‘ on line 32.

Over mij


  • _VpS_
  • Registratie: September 2002
  • Laatst online: 14-04 13:50
Ja, page, session en response level lcid's worden niet gebruikt. Metabase lcid is identiek op beide servers (2048).

(bb) || !(bb)


  • RobIII
  • Registratie: December 2001
  • Laatst online: 13:54

RobIII

Admin Devschuur®

^ Romeinse Ⅲ ja!

En de Locale settings zijn voor IUSR (of de user waaronder de website draait) ook beiden hetzelfde? Of heb je alleen de administrator (of je eigen) user gecontroleerd?

There are only two hard problems in distributed systems: 2. Exactly-once delivery 1. Guaranteed order of messages 2. Exactly-once delivery.

Roses are red Violets are blue, Unexpected ‘{‘ on line 32.

Over mij


  • _VpS_
  • Registratie: September 2002
  • Laatst online: 14-04 13:50
Ik zat inderdaad in die richting te kijken. Het blijkt dat de COM+ component op de 2de server onder een eigen locale identity draaide die 1043 als locale had staan. Dat zoiets triviaals zoveel tijd kon kosten.

Thanks for all the help.

(bb) || !(bb)

Pagina: 1


Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee