视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
ACCESS数据库向MySQL快速迁移小程序_MySQL
2020-11-09 17:15:34 责编:小采
文档


Access

近日,本人为了将为公司开发的一个信息管理系统从以前试运行的开发机器上(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源程序
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~





$dbconnection = @mysql_connect("yourmysqlserver", "mysqlaccount", "mysqlpassword")

or die ("can not connect to database server");

@mysql_select_db("yourdatabase")

or die("

No Database,

") ;

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

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



?>





Fields List of Two tables




$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 " Fd1 = " . $fdlist1 ;

$fdlist1 = substr($fdlist1,0,strlen($fdlist1)-1) ;

$fdlist2 = "" ;


$sqlquery = "select * from " . $mysql_table . " where 1=2 " ;

$records2 = mysql_query ($sqlquery) ;

$idcount2 = mysql_num_fields ( $records2 ) ;



for ( $i = 0 ; $i < $idcount2 ; $i )

$fdlist2 .= mysql_field_name($records2,$i )."," ;

echo " FD2 = " . $fdlist2 ;

$fdlist2 = substr($fdlist2,0,strlen($fdlist2)-1) ;

$fp = fopen ("fdlist.txt","w") ;

fwrite ($fp,$ctable) ;

fwrite ($fp,"n");

fwrite ($fp,$fdlist1) ;

fwrite ($fp,"n");

fwrite ($fp,$etable) ;

fwrite ($fp,"n") ;

fwrite ($fp,$fdlist2) ;

fclose($fp) ;

odbc_close($conn);

if ( $idcount2 != $idcounts ) {

echo "
".

" The fields of two tables doesn't match" ;

echo "

ODBC_table Fields = " . $idcounts;

echo "

MySQL_table Fields = " . $idcount2;
}
?>





~~~~~~~~~~~~~~~~~~~
未完接(二)
~~~~~~~~~~~~~~~~~~~

下载本文
显示全文
专题