IT猫扑网:您身边最放心的安全下载站! 最新更新| 软件分类| 专题汇总| 手机版

您当前所在位置:IT猫扑网 > 数据库 > MSSQL > SQL Server数据库导入MySQL数据库体验

SQL Server数据库导入MySQL数据库体验

时间:2015-06-28 00:00 来源:IT猫扑网|http://www.itmop.com/ 作者:网管联盟 我要评论(0)

因工作需要,要将存放在sql server数据库中的数据全部导入到mysql数据库中,在网上搜集相关资料,找到两种方法,现在分别谈谈对他们的看法。

第一种是安装mysql ODBC,利用sql server的导出功能,选择mysql数据源,进行数据的直接导出,这种方法很简便,但是针对实际应用有很多弊端,最主要体现就是数据类型问题,首先,sql server数据库中的ntext,image等数据类型的数据无法直接写入到mysql数据库中,据说只要稍加改动就可以,可惜偶这只菜鸟还没想到如何改动,其次,因为偶在mysql中的数据库设计中将时间都设成int型(保存的是时间戳),所以在数据导过来后,就会出现冲突,再次,这种方法生成的mysql数据表的字段类型都不很合适,所以此种方法我觉得不能提倡。

第二种是利用php或asp脚本来实现数据的导入功能,这种方法需要编写程序,但灵活性大,操作也不是那么困难,一切都尽在你的掌握之中,现简单介绍一下该方法。前提条件是你的mysql环境已经搭建好了,先建好目标数据库,再将所有的表结构用sql语句生成,现在万事具备,只缺数据了。

可以通过下面的php脚本来实现sql server中mydb数据库的user表中数据向mysql中mydb数据库导入:

以下为引用的内容:

  <?
  $cnx = odbc_connect('web', 'admin', '123456');
    //'web'是sqlserver中mydb的数据源名,
    'admin'是访问mydb的用户名,'123456'是访问mydb的密码
  $cur= odbc_exec( $cnx, 'select * from user' );
    //打开sql server中mydb数据库的user表
  $num_row=0;
  $conn=mysql_pconnect(&localhost&,&root&,&123456&);
    // 连接mysql
  @mysql_select_db('mydb',$conn) or
  
  die(&无法连接到数据库,请与管理员联系!&);
    //打开mysql的mydb数据库
  while( odbc_fetch_row( $cur ))
    //从sql server的mydb库中的user表逐条取出数据,如果对数据进行选择,
    可在前面的select语句中加上条件判断
  {
  $num_row++;
  $field1 = odbc_result( $cur, 1 );
    // 这里的参数i(1,2,3..)指的是记录集中的第i个域,
    你可以有所选择地进行选取,fieldi得到对应域的值,然后你可以对fieldi进行操作
  $field2 = odbc_result( $cur, 2 );
  $field3 = odbc_result( $cur, 3 );
  $field4 = odbc_result( $cur, 4 );
  $field5 = odbc_result( $cur, 5 );
  $field6 = odbc_result( $cur, 6 );
  $field5 = timetoint($field5); //这里是对sql server中的datetime类型
    的字段进行相应转换处理,转换成我所需要的int型
  $querystring = &insert into user
  (id,name,username,password,recdate)
  values('$field1','$field2','$field3','$field4','$field5')& ;
  
  mysql_query($querystring,$conn);
  }
  
  function timetoint($str){
  $arr1=split(& &,$str);
  $datestr=$arr1[0];
  $timestr=$arr1[1];
  $arr_date=split(&-&,$datestr);
  $arr_time=split(&:&,$timestr);
  $year=$arr_date[0];
  $month=$arr_date[1];
  $day=$arr_date[2];
  $hour=$arr_time[0];
  $minute=$arr_time[1];
  $second=$arr_time[2];
  $time_int=mktime($hour,$minute,$second,$month,$day,$year);
  return $time_int;
  }
  ?>

将该段脚本存成sql.php,在服务器上执行,就可以将服务器上sql server中mydb数据库的user表中的数据导入到mysql中mydb数据库的user表中去。其他表的操作与此雷同,就不赘述了。

下面再介绍一下asp脚本实现sql server中mydb数据库的数据向mysql中mydb数据库导入:

以下为引用的内容:

  <%
  set conn=server.createobject(&adodb.connection&)
  conn.open 'web', 'admin', '123456' // 'web'是sqlserver中mydb的数据源名,
    'admin'是访问mydb的用户名,'123456'是访问mydb的密码
  set rs=server.createobject(&adodb.recordset&)
  sql=&select ID,name,username,password,
    datediff(s,'1970-01-01 00:00:00',recdate)-
    8*3600,reid,filename,fileContentType,filevalue from senddate&
    //这条sql语句实现了将datetime类型的recdate字段转化成unix时间戳的int型
  
  rs.open sql,conn,1,3
  set conn1=server.createobject(&adodb.connection&)
  conn1.open &myoa&,&root&,&q1-d6=7?&
  i=1
  do while not rs.eof
  field1 = rs(0)
  field2 = rs(1)
  field3 = rs(2)
  field4 = rs(3)
  field5 = rs(4)
  sql1 = &insert into user(ID,name,username,password,recdate)
  
  values(&&field1&&,'&&field2&&','&&field3&&','&&field4&&',&&field5&&)&
  
  conn1.execute sql1
  rs.movenext
  i=i+1
  loop
  rs.close
  set rs=nothing
  conn.close
  set conn=nothing
  conn1.close
  set conn1=nothing
  
  %>

以上两个是分别采用php脚本和asp脚本对user表的数据进行由sql server到mysql的导入其间我采用2种回避的方法来避免ntext,image类型数据的传递,一种是将ntext字段改为nvarchar(4000),因为实际情况,原始数据中该字段的数据长度都未超过4000个字,所以并没有出现数据截断,另一个手段是将image类型数据取出来写到文件中,以文件形式保存,将文件路径存到数据库中,方法见下:

以下为引用的内容:

  
  function makeattach(fileContentType,filevalue,i)
  select case fileContentType
  case &application/msword&
  ext=&doc&
  
  case &application/vnd.ms-excel&
  ext=&exl&
  
  case &application/vnd.ms-PowerPoint&
  ext=&pps&
  
  case &application/x-rar-compressed&
  ext=&rar&
  
  case &application/x-zip-compressed&
  ext=&zip&
  
  case &image/gif&
  ext=&gif&
  
  case &image/pjpeg&
  ext=&jpg&
  
  case &text/plain&
  ext=&txt&
  
  case else
  ext=&x&
  
  end select
  if ext<>&x& then
  set fso=server.createobject(&FileSystemObject&)
  fName=&attech&&i&&.&&ext
  Dir=&d:attach&
  If fso.FileExists(Dir & fName) Then fso.deletefile Dir & fName
  If fName<>&& AND NOT fso.FileExists(Dir & fName) Then
  Set strm1=Server.CreateObject(&ADODB.Stre

关键词标签:SQL Server,MySQL,数据

相关阅读 sql server系统表损坏的解决方法 SQL Server asp.net 数据提供程序连接池 SqlServer2005对现有数据进行分区具体步骤 一个Access数据库数据传递的实例方法 为导入文件加上时间戳标记的两种方法 SQL Server 2005 在不允许远程连接的情况下的破解

文章评论
发表评论

热门文章 sql server系统表损坏的解决方法 sql server系统表损坏的解决方法 SqlServer2005对现有数据进行分区具体步骤 SqlServer2005对现有数据进行分区具体步骤 解决SQL Server中Group无法实现的问题 解决SQL Server中Group无法实现的问题 SQL Server 2005降级到2000的正确操作步骤 SQL Server 2005降级到2000的正确操作步骤 手把手教你学会SQL Server镜像操作 手把手教你学会SQL Server镜像操作 实战手记:让百万级数据瞬间导入SQL Server 实战手记:让百万级数据瞬间导入SQL Server

相关下载

人气排行 配置和注册ODBC数据源-odbc数据源配置教程 如何远程备份(还原)SQL2000数据库 SQL2000数据库远程导入(导出)数据 SQL2000和SQL2005数据库服务端口查看或修改 修改Sql Server唯一约束教程 SQL Server 2005降级到2000的正确操作步骤 sql server系统表损坏的解决方法 浅谈JSP JDBC来连接SQL Server 2005的方法 SQL Server创建表语句介绍 MS-SQL2005服务器登录名、角色、数据库用户、角色、架构的关系 如何使用SQL Server中的客户端配置工具 SQL Server 分布式查询:OLE DB连接(一)