从数据库 sql server2005中向 MySql数据库中转移数据库。在网上找了一个 MySQLMigrationToolkit(2) 工具 挺好用的 。好几样数据库都可以转换成mySql数据库。
但唯一可惜的 据说不支持中文数据。结果 导入的中文数据都是 乱码。最后又在网上找了一个 导出sql server 2005数据的存储过程 。写的真不错,就修改了一点 结果都能导
出来了。
CREATE PROCEDURE dbo.UspOutputData
@tablename sysname
AS
declare @column varchar(8000)
declare @columndata varchar(8000)
declare @sql varchar(8000)
declare @xtype tinyint
declare @name sysname
declare @objectId int
declare @objectname sysname
declare @ident int
set nocount on
set @objectId=object_id(@tablename)
if @objectId is null -- 判断对象是否存在
begin
print 'The object not exists'
return
end
set @objectname=rtrim(object_name(@objectId))
if @objectname is null or charindex(@objectname,@tablename)=0 --此判断不严密
begin
print 'object not in current database'
return
end
if OBJECTPROPERTY(@objectId,'IsTable') < > 1 -- 判断对象是否是table
begin
print 'The object is not table'
return
end
select @ident=status&0x80 from syscolumns where id=@objectid and status&0x80=0x80
if @ident is not null
print 'SET IDENTITY_INSERT '+@TableName+' ON'
declare syscolumns_cursor cursor
for select c.name,c.xtype from syscolumns c where c.id=@objectid order by c.colid
open syscolumns_cursor
set @column=''
set @columndata=''
fetch next from syscolumns_cursor into @name,@xtype
while @@fetch_status < >-1
begin
if @@fetch_status < >-2
begin
if @xtype not in(189,34,35,99,98) --timestamp不需处理,image,text,ntext,sql_variant
暂时不处理
begin
set @column=@column+case when len(@column)=0 then'' else ','end+'`'+@name+'`'
set @columndata=@columndata+case when len(@columndata)=0 then '' else ','','','
end
+case when @xtype in(167,175) then '''''''''+'+@name+'+''''''''' --varchar,char
when @xtype in(231,239) then '''N''''''+'+@name+'+''''''''' --nvarchar,nchar
when @xtype=61 then '''''''''+convert(char(23),'+@name+',121)+''''''''' --datetime
when @xtype=58 then '''''''''+convert(char(16),'+@name+',120)+''''''''' --smalldatetime
when @xtype=36 then '''''''''+convert(char(36),'+@name+')+''''''''' --uniqueidentifier
else @name end
end
end
fetch next from syscolumns_cursor into @name,@xtype
end
close syscolumns_cursor
deallocate syscolumns_cursor
set @sql='set nocount on select ''insert '+@tablename+'('+@column+') values(''as ''-
-'','+@columndata+','');'' from '+@tablename
print '--'+@sql
exec(@sql)
if @ident is not null
print 'SET IDENTITY_INSERT '+@TableName+' OFF'
MySQLMigrationToolkit(2) 工具 由于大于 10MB上传不上去。
分享到:
相关推荐
将mysql数据库转换为sql server的数据库,或者将sql server数据库转换为mysql的数据库,在nt环境下很多时候都会用到。使用mysql odbc后就比较好办,可以使用sql server的管理工具,也可以使用mysql的管理工具,更可以...
将sqlserver数据导入MySql中的工具,里面附带说明
SqlServer中的数据导入到Mysql数据库中
使用flink-connector-sqlserver-cdc 2.3.0把数据从SQL Server实时同步到MySQL中。
谈谈数据从sql server数据库导入mysql数据库的体验
mssql数据迁移方案,有kettle,sqlyong,navcat,datax等方式迁移,还可以支持分片式数据库库迁移,让数据迁移更方便,定时任务离线数据迁移
SQLServer2005数据导入Mysql到详细教程
将Mysql数据库导入到SQLSERVER里面
实现从SQL_Server中提取数据导入到Mysql数据库
然后把sqlserver的倒出来的库文件导入到sqlserver2005中去。实例打开SQL Server Management Studio点击连接——》右键数据库——》选择还原数据库在点击选项路径一定 要正确好了再去看shiyan这个数据库就有表文件了...
将sql中数据读出导入到mysql中的java代码实现,希望能够帮到有需要的朋友
SQL Server导入MySQL,包括表结构及数据,uniqueidentifier 需要改变为字符类型
从MYSQL 里导入数据到SQL SERVER2005
PowerDesigner导出的SQL带列注释,导入到MySQL中列注释不见了的处理方法
文中介绍了将存放在sql server数据库中的数据全部导入到mysql数据库中的两种方法。第一种是安装mysql ODBC,利用sql server的导出功能,选择mysql数据源,进行数据的直接导出,这种方法很简便,但是针对实际应用有很...
Navicat for SQL Server 是一套专为 Microsoft SQL Server设计的...它可以让用户连接到任何本机或远程 SQL Server、提供一些实用的数据库工具如数据模型工具、数据同步、结构同步、导入、导出及报表以协助管理数据。
SqlServer转mysql 导入表结构 表数据
Excel批量导入SSIS并将包发布到SQL Server
可以导入eclipse的cas server项目工程,配置了mysql数据库或者sql server数据库,添加了des自定义加密算法,可改造
里面有Sqlserver连接客户端和Mysql数据库连接客户端,都是注册版本哦,方便日常数据库操作,数据可以直接导入导出excel文件