"Dan Lewis" <waynelewis@gmail.com> wrote in message
news:1142289238.674588.225400@i39g2000cwa.googlegr oups.com...[color=blue]
> I've imported a ms access database into a table in a mysql database.[/color]
Have you checked out the MySQL Migration Toolkit, which is supposed to help
with this task?
http://dev.mysql.com/doc/migration-t.../en/index.html
[color=blue]
> The access database contains a field that holds date/time values in
> 'general date' format. These all show up at 01/01/1970 in the mysql
> database.[/color]
Sounds like the values were truncated to zero during the import. This
stores the value 0 relative to the UNIX time epoch (1970-01-01 00:00:00
UTC).
[color=blue]
> I believe the field in mysql is wanting UTC and shows
> numbers when looked at from the sql command line (i.e. March 13, 2006,
> 5:31 pm is shown as 1142289086).[/color]
I'm not sure what you mean here. MySQL is supposed to adjust time values
when you enter them, according the timezone you have configured for the
mysqld server or a per-connection timezone override. Then time values are
stored in UTC, and adjusted back to the server or connection timezone during
queries.
[color=blue]
> How do I get the access data into that format so it will import properly?[/color]
MySQL date values must be strings in a limited number of specific formats,
e.g. 'YYYY-MM-DD HH:MM:SS'. See
http://dev.mysql.com/doc/refman/5.0/en/datetime.html for the legal formats.
You either need to export the data from MS Access in a MySQL-compatible
format, or else use the STR_TO_DATE function in MySQL to parse the MS Access
date strings into a valid MySQL date format. For example:
INSERT INTO myTable (dateField)
VALUES ( STR_TO_DATE('Monday, March 13, 2006', '%W, %M %e, %Y') );
See docs for DATE_FORMAT and STR_TO_DATE here:
http://dev.mysql.com/doc/refman/5.0/...functions.html
Regards,
Bill K.