MSSQL 数据库复制到 MySQL

MSSQL 数据库复制到 MySQL

我有 MSSQL 2005 服务器,并且在内网中有 MySQL 数据库。我想将一些表从 MSSQL 数据库复制到 MySQL 数据库。

我已经创建了 ODBC 链接服务器,并成功创建了事务发布,并且我已经在 MySQL 中手动创建了完全相同的表,并且复制似乎正在正常工作。

我之所以手动在 MySQL 中创建表,是因为在 MSSQL 的复制中创建键和索引时出现了问题。复制运行时,它会将 varchar(200) 字段转换为 MySQL varchar,而该字段在 MySQL 表中变为 mediumtext,并在尝试创建主键或索引时显示错误。我应该如何配置发布以在 MySQL 中创建具有正确长度的表字段的精确副本?

我在服务器上安装了 MySQL ODBC 5.1 驱动程序。

编辑:

当我看到 MySQL.Log 文件时,它显示查询

CREATE TABLE `Inventory`(
    `SKU`   long varchar NOT NULL,

随后在 MySQL 数据库中变为 mediumtext。显示类似以下错误

BLOB/TEXT column 'SKU' used in key specification without a key length

在 MSSQL 复制作业历史记录中。当我查看 MySQL 中的表时,“SKU”的字段类型是 mediumtext。

答案1

您可能可以使用 SQuirreL SQL 客户端(Java 版)导出表,然后通过 JDBC 将其导入 MySQL。我怀疑是否有 ODBC 方法可以满足您的需要。

另外,您可以将 SQL 数据库导出为 CSV 文件,然后使用以下命令导入 MySQL:

LOAD DATA LOCAL INFILE C:\test.csv
INTO TABLE tbl_temp_data 
FIELDS TERMINATED BY ','
LINES TERMINATED BY '\r\n'

答案2

为所有文章设置@schema_option = 0x0000000000000000 以便 SQL Server 不会触碰任何内容。

答案3

另外,创建发布、添加文章和创建订阅时不要使用 GUI,因为它会搞砸一切。使用 SQL 脚本手动完成所有操作。

相关内容