我有 MSSQL 2005 服务器,并且我在 Intranet 中有 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”的字段类型是中文本。
您可能可以使用 SQuirreL SQL 客户端(在 Java 中)导出表,然后通过 JDBC 将它们导入 MySQL。我怀疑是否有一种 ODBC 方法可以满足您的需求。
此外,您可以将 SQL 数据库导出为 CSV 文件,然后使用以下命令导入 MySQL:
为所有文章设置@schema_option = 0x000000000000000,这样 SQL Server 就不会触及任何东西。
此外,在创建出版物、添加文章和创建订阅时不要使用 GUI,因为它会搞砸一切。使用 SQL 脚本手动执行所有操作。