Solved

LCID and CODEPAGE problem

Posted on 2004-08-13
9
1,584 Views
Last Modified: 2008-03-10
Hi

I've got a problem with Codepage, LCID, and related matters. I highly appreciate any help. The solution is not that urgent in respect to time, but is very important to me in general.
My server runs IIS 5 on WinXP. Although Farsi is installed on the server, I have set Windows locale to English (United States).
What I want to do is to store the date of page visits in an Access 2003 database. The Access DB file is created on the same machine.
Now, what I need is the date is stored in ENGLISH locale format not other.
When I run this:

<%
response.Write now()
%>

it gives me such:

8/13/2004 10:53:40 PM

and when I run this:

<%
session.LCID = 1065
response.Write now()
%>

,where 1065 is the locale ID for Farsi, I get this:

2004/08/13 10:53:52 &#1576;.&#1592;

(The last two characters mean just the same as PM. You may see them odd.)

When I run this:

<%
session.LCID = 1033
response.Write now()
%>

,obviuosly, I get the English date format again:

8/13/2004 10:54:05 PM

Now the problem: I use such code (simplified) to store the date in the db:

<%
dim conn, recset, connStr, SqlStr
connStr = "Driver={Microsoft Access Driver (*.mdb)};Dbq=" & server.MapPath("db1.mdb")
set conn = server.CreateObject("ADODB.connection")
conn.open connStr
set recset = server.CreateObject("ADODB.recordset")
SqlStr = "SELECT x FROM Table1"
recset.open SqlStr,conn,,3
'while not recset.eof
'      response.write recset.Fields("x").value & "<br />"
'      recset.movenext
'wend
recset.AddNew
recset.Fields("x")=now()
recset.update
response.write "<br />" & now()
recset.close
set recset = nothing
set conn = nothing
%>

This saves the date in Farsi locale format. Even if I set the locale ID to 1033 (or anything, no matter what!) it continues saving that in Farsi format.
I guessed this is because incorrect Codepage format. I tried several possible codepages, from 1252 to 65001 (UTF-8), but no way!
If we accept that now() function returns a string, then this string must be the same, when it is used in response.write, and when it is part of a SQL Querry, but it is not in reality!

Any help is highly appreciated.
Huji


By the way, it took me a long time to know that Farsi locale is 1065, and I am looking for a complete list of locale IDs, and codepages, for different languages. This can be helped too.
0
Comment
Question by:huji
  • 6
  • 3
9 Comments
 
LVL 14

Author Comment

by:huji
ID: 11795674
I again want to explain that, &#1576;.&#1592; stands for two Farsi letters, which are shown in Farsi in the real page, but as EE changes them to the equivallent UNICODE char on submitting a post, you see them this way. Anyways, I dislike them!

Huji
0
 
LVL 14

Author Comment

by:huji
ID: 11795715
And finally I found the best resource for LCIDs. So please focus to the main question.
Thanks
Huji
(Here it is for others reference: http://www.microsoft.com/globaldev/reference/lcid-all.mspx)
0
 
LVL 14

Author Comment

by:huji
ID: 11801293
I would be a little happy if I know that ONE person has understood my question, even if not known the answer yet!
Waiting
huji
0
Courses: Start Training Online With Pros, Today

Brush up on the basics or master the advanced techniques required to earn essential industry certifications, with Courses. Enroll in a course and start learning today. Training topics range from Android App Dev to the Xen Virtualization Platform.

 
LVL 14

Author Comment

by:huji
ID: 11803431
Hey guys, I have to mention that I have found at least to ways that can solve the issue:
1)If I pass CStr(now()) to the DB instead of the now() itself, this will solve the issue.
2)If I change the data type of the x column in my DB from Text to Date/Time, this again solves the issue.
But the main question still remains:
When I set the LCID to 1033 (English), why is the value of now() still in Farsi format?
Regards,
Huji
0
 
LVL 46

Expert Comment

by:fritz_the_blank
ID: 11816440
First, I should say that the most reliable way is to enter the date in VBLongDate format:

http://www.devguru.com/Technologies/vbscript/quickref/formatdatetime.html

The next most reliable way is to use the yyy/mm/dd format.

Let me reread this whole thread when I get a few minutes so that we can figure out why this is happening.

ftB
0
 
LVL 14

Author Comment

by:huji
ID: 11817984
Thanks Fritz
Huji
0
 
LVL 46

Accepted Solution

by:
fritz_the_blank earned 500 total points
ID: 11819729
Okay, what happens is this:

1) the LCID only effects the formatting of how the date is displayed on the page
2) the regional settings on the server dictate how the date will be stored in the database

This is normal behaviour (do a search within the ASP area for LCID and you'll see what I mean) but it is totally confusing. You would expect that the format displayed on the page would be the format entered into the database (at least that is what I thought when I first encountered this) but that is not true. The only reason that I can think of is that someone might want to have a series of different pages for different nationalities on the same site, each displaying currency and date appropriately. However, there would need to be one standard for the database, and logically, that would be the regional settings on the server.

Fritz the Blank
0
 
LVL 14

Author Comment

by:huji
ID: 11821808
Good explanation. That's just what I needed.
Huji
0
 
LVL 46

Expert Comment

by:fritz_the_blank
ID: 11821838
Glad to have helped,

FtB
0

Featured Post

Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

Question has a verified solution.

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

I have helped a lot of people on EE with their coding sources and have enjoyed near about every minute of it. Sometimes it can get a little tedious but it is always a challenge and the one thing that I always say is:  The Exchange of information …
Hello, all! I just recently started using Microsoft's IIS 7.5 within Windows 7, as I just downloaded and installed the 90 day trial of Windows 7. (Got to love Microsoft for allowing 90 days) The main reason for downloading and testing Windows 7 is t…
Migrating to Microsoft Office 365 is becoming increasingly popular for organizations both large and small. If you have made the leap to Microsoft’s cloud platform, you know that you will need to create a corporate email signature for your Office 365…
This is used to tweak the memory usage for your computer, it is used for servers more so than workstations but just be careful editing registry settings as it may cause irreversible results. I hold no responsibility for anything you do to the regist…

816 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

Need Help in Real-Time?

Connect with top rated Experts

12 Experts available now in Live!

Get 1:1 Help Now