AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 101626
In Process
THEn
THEn
Asked: 2010-01-12 10:16:18 +0800 CST2010-01-12 10:16:18 +0800 CST 2010-01-12 10:16:18 +0800 CST

MSSQL 数据库复制到 MySQL

  • 772

我有 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”的字段类型是中文本。

sql-server replication database-replication
  • 3 3 个回答
  • 2566 Views

3 个回答

  • Voted
  1. djangofan
    2010-01-12T10:25:40+08:002010-01-12T10:25:40+08:00

    您可能可以使用 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'
    
    • 1
  2. user57306
    2010-10-16T13:09:43+08:002010-10-16T13:09:43+08:00

    为所有文章设置@schema_option = 0x000000000000000,这样 SQL Server 就不会触及任何东西。

    • 1
  3. user57306
    2010-10-16T13:23:59+08:002010-10-16T13:23:59+08:00

    此外,在创建出版物、添加文章和创建订阅时不要使用 GUI,因为它会搞砸一切。使用 SQL 脚本手动执行所有操作。

    • 1

相关问题

  • sql server 连接字符串上的网络数据包大小以提高吞吐量

  • 基于 Microsoft 的服务器(IIS、MSSQL 等)上的病毒扫描应排除哪些内容?

  • SQL 洗衣清单

  • OPENROWSET、二进制文件、varchars 和 varbinaries

  • 聚集索引与非聚集索引?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve