如何把sqlserver数据迁移到mysql数据库及需要注意事项

如何把sqlserver数据迁移到mysql数据库及需要注意事项,第1张

以下有几款迁移工具的对比,可以参考,比较推荐DB2DB

软件易用性主要是指软件在导入前的配置是否容易。由于很多软件设计是面向程序员而非一般的数据管理人员、甚至是普通的应用程序实施人员,而这一类人员很多时候并没有数据源配置经验。因为一些使用 ODBC 或者 ADO 进行配置的程序往往会让这类用户造成困扰(主要是不知道应该选择什么类型的数据库驱动程序)。下面让我们看看四个工具的设计界面:

>>>>

1、SQLyog

SQLyog 使用的是古老的 ODBC 连接,但对于新一代的程序来说,这种方式的非常的不熟悉并且不容易使用,并且必须要求本机安装好相应的数据库的 ODBC 驱动程序(SQL Server 一般自带好)。

>>>>

2、Navicat Premium

NavicatPremium是四个应用工具中设计最不人性化的一个:从上图怎么也想像不到要点按那个小按钮来添加一个新的连接,并且这个连接设置不会保存,每次导入时都必须重新设置。NavicatPremium使用的是比 ODBC 稍先进的 ADO 设置方式(199X年代的产物),但使用上依然是针对老一代的程序员。

>>>>

3、Mss2sql

Mss2sql 是最容易在百度上搜索出来的工具,原因之一是它出现的时间较早。

Mss2sql由于是很有针对性的从 SQLServer 迁移到 MySQL,因为界面使用了 *** 作向导设计,使用非常容易。同时在设置的过程中,有非常多的选项进行细节调整,可以感觉到软件经过了相当长一段时间的使用渐渐完善出来的。

>>>>

4、DB2DB

DB2DB 由于是由国人开发,因此无论是界面还是提示信息,都是全程汉字。另外,由于 DB2DB 在功能上很有针对性,因为界面设计一目了然和易使用。和 mss2sql 一样, DB2DB 提供了非常多的选项供用户进行选择和设置。

三、处理速度和内存占用评测

在本评测前,本人的一位资深同事曾经从网上下载了某款迁移软件,把一个大约2500万记录数的数据表转送到阿里云 MySQL,结果经过了三天三夜(好在其中两天是星期六和星期日两个休息日)都未能迁移过来。因此这一次需要对这四个工具的处理速度作一个详细的测试。

考虑到从 SQL Server 迁移到 MySQL 会出现两种不同的场景:

从 SQL Server 迁移到本地 MySQL 进行代码测试和修改;

从 SQL Server 迁移到云端 MySQL 数据库正式上线使用;

以下为测试过程中的截图:

>>>>

1、SQLyog

>>>>

2、Navicat Premium

注意:我们在测试 Navicat Premium 迁移到  MySQL 时发现,对于 SQL Server 的 Money 类型支持不好(不排除还有其它的数据类型支持不好)。Money 类型字段默认的小数位长度为 255,使得无法创建数据表导致整个测试无法成功,需要我们逐张表进行表结构修改才能完成测试过程。

Navicat Premium 的处理速度属于中等,不算快也不算慢,但 CPU 占用还有内存占用都处于高位水平。不过以现在的电脑硬件水平来说,还是可以接受。但 CPU 占用率太高,将使得数据在导入的过程中,服务器不能用于其它用途。

>>>>

3、Mss2sql

Mss2sql 并没有提供计时器,因此我们使用人工计时的方法,整个过程处理完毕大于是 726 秒。Mss2sql 的 CPU 占用率相对其它工具来说较高,但仍属于可以接受的范围之内。

>>>>

4、DB2DB

DB2DB 同样迁移 300万数据时,仅仅使用了 2 分 44 秒,这个速度相当惊人。不过最后的结果出现一个 BUG,就是提示了转换成功,但后面的进度条却没有走完(在后面的数据完整性评测中,我们验证了数据其实是已经全部处理完毕了)。

1、新增用户qianyi赋予权限。

2、创建一个新库qianyidb。

3、创建模式,这里两行的qianyidb不一样,第一行的qianyidb表示数据库,第二行的qianyidb表示模式。

4、迁移数据,将原数据迁移到qianyi用户的qianyidb模式下即可。

跨平台的迁移数据库,一般采用导出/导入.

这是其中一种方法,非常简单

1 导出数据库数据

mysqldump -uroot -p dp_db > dumpoutsql

其中 root是账户名

dp_db是需要导出的数据库名称

dumpoutsql存储导出的数据

2 将导出的数据dumpoutsql放到你的目标机器上(如果是远程目标机器的话,直接将dunmpoutsql copy到目标机器就行)。这里假设cp到主目录下~/

3 在目标机器的数据库里建立新数据库,这里建立名为dp_db_bak的数据库

mysql> create database dp_db_bak

4 向dp_db_bak数据库导入数据

mysql -uroot -p dp_db_bak < ~/dumpoutsql

其中 root是账户名

db_db_bak是新数据库

~/dumpoutsql是第一步导出的数据

PS 如果在导入导出数据的时候遇到文件太大异常退出的情况,可使用split/cat来进行文件的分割和合并

mysqldump -uroot -p dp_db | split -b 10m - tempfile

cat all_tempfile > targetfile

其他方法:

Mysql source命令在导入大数据时显得非常有用。虽然Mysql Administrator软件也不错,但就稳定性和效率性来说还是source占优。

使用方法:

Windows下将sql数据库备份拷贝到磁盘目录如:D:\dbsql,cmd进入命令行。

1、先使用命令mysql -uroot -p登陆mysql服务器

2、然后执行相关命令导入数据。

mysql> use dbtest; //设置当前要导入数据的dbtest数据库

mysql> set names utf8; //设置编码

mysql> source D:\dbsql; //导入数据

ok,完成。当然数据库备份用Mysql Administrator是非常方便的

Mysql导出表结构及表数据 mysqldump用法

命令行下具体用法如下: mysqldump -u用户名 -p密码 -d 数据库名 表名 脚本名;

1、导出数据库为dbname的表结构(其中用户名为root,密码为dbpasswd,生成的脚本名为dbsql)

mysqldump -uroot -pdbpasswd -d dbname >dbsql;

2、导出数据库为dbname某张表(test)结构

mysqldump -uroot -pdbpasswd -d dbname test>dbsql;

3、导出数据库为dbname所有表结构及表数据(不加-d)

mysqldump -uroot -pdbpasswd dbname >dbsql;

4、导出数据库为dbname某张表(test)结构及表数据(不加-d)

mysqldump -uroot -pdbpasswd dbname test>dbsql;

指定分隔符导出数据(貌似必须在本机才能正常执行),步骤:

1 cd /tmp

2 mkdir mysqldata

3 chown mysql:mysql mysqldata

4 mysqldump -h127001 -uroot -p123456 -T/mysqldata/ --fields-terminated-by=@@, dbname tablename

navicat工具来将SQL Server数据迁移到MySQL

新建需要迁移的数据库

打开数据库,点击导入向导

选择数据导入格式

选择数据源

设置连接属性

选定要迁移的表

定义目标表

更改实际情况对目标表进行更改

选择导入模式

开始导入

导入后结果

至此,迁移完成,可以更改实际情况再对迁移后的表进行更改。

1使用MSSQL2MYSQL 开源软件帮助你迁移;

2利用MSSQL软件提供的跨异构数据源的工具,直接远程数据写入到MySQL中;

3数据到导出为特殊分隔符的文本数据,再使用LOAD DATA 命令加载;

1、使用软件Navicat就可迁移复制数据库,打开Navicat,右键点击左边空白的地方,点击New Connection下的MySQL,创建一个服务器的连接,下面将演示把本地的数据迁移到服务器:

2、在d出的创建新连接的窗口里,输入服务器的IP,数据库账号,密码等,然后就可以连接数据库了:

3、创建好后们打开本地的数据库,点击“Data Transfer”(数据传输),接着d出新的界面:

4、新窗口中在左边选择本地数据库的库,和需要转移的表,可以选择一个,或多个表:

5、然后在右边的目标里,选择服务器的连接,然后选择服务器上的数据库:

6、选择完成后,就开始进行数据转移了,数据量不是很大的,很快就会转移完成的。以上就是mysql中数据复制到另一个数据库的方法:

赛迪网-IT技术报道Mysql数据库迁移Oracle数据库具体程:需要准备工具:1连接Mysql

jdbc

mysql-connector-java-504-binjar

2Oracle公司发SQL

Developer

12

面配置SQL

Developer

12

配置环境:选择Tools-Preferences

-Database-Third

Party

JDBC

Driver

点击

Add

Entry

添加Mysqljdbc

配置MySQLOracle连接

点击Connection

右键选择

New

Connection

别建立Mysql

Oracle连接

建立连接查看数据库

两种迁移数据式:1

Capture

the

source

database

or

tables

2

Convert

the

captured

database

or

tables

3

Generate

DDL

for

the

new

Oracle

schema

objects

4

Run

the

generated

DDL

script

to

create

the

new

user

and

objects

5

Copy

any

data

from

the

source

database

to

the

new

database,select

Migration->Migration

Data

select

a

converted

model

快速迁移:

选择要迁移表或数据库选择Migration

->

Quick

Migrate

(责任编辑:卢兆林)

1、用dump命令备份数据库。

# mysqldump -u root -p dbfile > dbfilesql

2、用rsync从新服务器获得备份的文件(SCP或WGET也可以)。

# rsync -avr root@myolddbserver:/home/mydumpfolder/dbfilesql

3、登陆新服务器的mysql客户端。

# mysql -u root -p

4 建立数据库。

mysql> create database dbfile;

5 选择新数据库;

mysql> use dbfile;

6 加载数据;

mysql> source dbfilesql

或者

在Mysql程序中有我自己的一个数据库共5张表,里边数据不算太多。我现在想把他们全部弄到另一台电脑中去,该怎么弄,如果不用其它的软件工具,只用Mysql自已的程序不知可否?

注:不用考虑 *** 作系统。

---------------------------------------------------------------

在dos命令提示符下使用mysqldump命令进行备份

如下:

C:\Documents and Settings\Administrator>mysqldump yinshi >c:\\backuptxt -uroot

-p12142022

说明:yinshi是我的数据库名,里面有5张表; c:\\backuptxt 是我备份出来文件名和路径;

-u,-p参数后面跟的分别是用户名和密码

将你备份出来的文件我这里是backuptxt拷贝到另一台机上,再在dos命令提示符下用mysql命令,进行恢复,如下:

C:\Documents and Settings\Administrator>mysql < c:\\backuptxt -uroot -p12142022

or

mysql>source backuptxt;(这里backuptxt在放在data目录下)

---------------------------------------------------------------

如果另一台机器上也安装了mysql,可以直接导入

C:\mysql\bin>mysqldump -h172206250 -udeveloper -p123456 --opt server_databasename | mysql -hlocalhost -uroot -C obj_databasename

172206250源服务器ip

developer源服务器连接用户名

---------------------------------------------------------------

有两种办法。

1、在B机器上装mysql。

将A机器上的mysql/data下的你的数据库目录整个拷贝下来。

将B机器上的mysql服务停止。

找到B机器上的mysql/data目录,将你拷贝的目录粘贴进去,然后启动mysql服务就可以了。

2、使用SQL语句备份和恢复

你可以使用SELECT INTO OUTFILE语句备份数据,并用LOAD DATA INFILE语句恢复数据。这种方法只能导出数据的内容,不包括表的结构,如果表的结构文件损坏,你必须要先恢复原来的表的结构。

语法:

SELECT INTO {OUTFILE | DUMPFILE} ’file_name’ FROM tbl_name

LOAD DATA [LOW_PRIORITY] [LOCAL] INFILE ’file_nametxt’ [REPLACE | IGNORE]

INTO TABLE tbl_name

SELECT INTO OUTFILE ’file_name’

以上就是关于如何把sqlserver数据迁移到mysql数据库及需要注意事项全部的内容,包括:如何把sqlserver数据迁移到mysql数据库及需要注意事项、金仓数据库迁移到mysql、mysql数据从windows迁移到linux中怎么搞等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9407428.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存