ACCESS数据库向MySQL快速迁移小程序(一)

鏅擆煒婃晱

鏅擆煒婃晱

2016-01-29 14:54

ACCESS数据库向MySQL快速迁移小程序(一),ACCESS数据库向MySQL快速迁移小程序(一)
  近日,本人为了将为公司开发的一个信息管理系统从以前试运行的开发机器上(Windows NT + IIS4.0 + Access)迁移至一台真正的Linux服务器上(Apache1.3.12 + PHP 4.03 + MySQL 3.23.26),其中数据库中的几十个表的内容迁移,开始让我小费了一些周折,从网上也下载了一些MySqL的客户软件或是数据库管理软件,写得较好的软件均有数据迁移功能,但其迁移方式不外乎两种,一种是采用文件引入方式,此种方式在处理数据库中有和分隔符相同的字符时,会产生错误,尤其是在处理ACCESS中的Memo字段,很容易出错,最后导致导出后的数据不是多了就是少了。而另一种支持ODBC直接导入的功能较强,基本可无错误地导入各个表的内容,但很遗憾,这必须是建立在ACCESS中表格的字段是英文是才可以,如在ACCESS中字段是中文名,一般也出错,不能成功导入。
为此我只好花了点时间写了两个小程序,用于将ACCESS数据库的内容向MySQL迁移,经使用,效果还不错,特在此写出奉献给各位一试或评判。

先概述一下使用方法,
1,将ACCESS的数据库建立一个"system DSN";
   2,根据ACCESS数据库中各表的名称,在MySQL中建立相应的各个空表;
3,运行fdlist.php;
   4,运行import.php;
   5,每运行一次3,4步可迁移一个表,然后修改fdlist.php中的ACCESS源表名和MySQL中的目标表名,再运行3,4步,直至迁移所有的表,

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
以下为 fdlist.php源程序
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~      
<html
<head
<style type=text/css
body,td,li,div,p,pre,a,b,h1,h2,h3,h4 {font-family:verdana;font-size:9pt;line-height : 18px;color:#a00000 }  
</style
</head
<?  

    $dbconnection = @mysql_connect("yourmysqlserver", "mysqlaccount", "mysqlpassword")  
     
        or die ("can not connect to database server");
     
    @mysql_select_db("yourdatabase")   
              
             or die("<p style='font-size:9pt;font-family:verdana;color:#803333;font-weight:bold'No Database,</p") ;  

    $odbc_table = "youroriginaltable" ;    // The original table name in your ODBC database

    $mysql_table = "yournewtable" ;        // The new table name in your Mysql Database.


     
?

<body bgcolor=#f0f0f0 topmargin=0 leftmargin=0 text=#a00000

<br
<div style="font-size:24pt;font-family:times;font-weight:bold;color:#00a000"Fields List of Two tables</div
<hr size=1 color=#900000

<?

    $conn = odbc_connect("task", "", "");
     
    $odbc_query = "select * from " . $odbc_table . " where 1=2";
     
    $recordsid = odbc_exec($conn, $odbc_query);
     
    $idcounts = odbc_num_fields( $recordsid ) ;

    $fdlist1 = "" ;
     
    for ( $i = 1 ; $i <= $idcounts ; $i ++)  
     
        $fdlist1 .=   odbc_field_name($recordsid,$i)."," ;
     
    echo "<div Fd1 = " . $fdlist1 ;
     
    $fdlist1 = substr($fdlist1,0,strlen($fdlist1)-1) ;
     
    $fdlist2 = "" ;
展开更多 50%)
分享

猜你喜欢

ACCESS数据库向MySQL快速迁移小程序(一)

电脑网络
ACCESS数据库向MySQL快速迁移小程序(一)

ACCESS数据库向MySQL快速迁移小程序(二)

电脑网络
ACCESS数据库向MySQL快速迁移小程序(二)

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

MS Access 数据库向 MS SQL Server 7.0 的迁移 (简述)

编程语言 网络编程
MS Access 数据库向 MS SQL Server 7.0 的迁移 (简述)

将mysql数据导入access数据库

编程语言 网络编程
将mysql数据导入access数据库

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

32位的MySQL数据库迁移到64位的MySQL数据库

编程语言 网络编程
32位的MySQL数据库迁移到64位的MySQL数据库

快速修复MySQL数据库

编程语言 网络编程
快速修复MySQL数据库

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

用PHP连接Oracle for NT 远程数据库

用PHP连接Oracle for NT 远程数据库

在PHP中使用灵巧的体系结构

在PHP中使用灵巧的体系结构
下拉加载更多内容 ↓