按计划今天着手进行将后台数据库从MS SQL Server2000转换成MySQL5.1.3。目的是便于发布软件的测试版本。

  1. 驱动: mysql-connector-odbc-5.1.11-win32.msi。测试Win7*64, XP通过, Win7*32、Win8的暂时没环境测试,待测。

  2. MySQL_5.1.3免安装版。

  3. MSS2SQL工具软件转换SQLServer2000的表结构。一共转换了43个表。

  4. MSSQLServer2000到MySQL的存储过程的转换

  (1)同表复制数据

  #接触MySQL没几天,写的语句自己也觉得有些啰嗦,肯定可以优化,只能深入学习之后再进行了。 

   # To-Do.  2015年5月18日 10:14:51

  DROP PROCEDURE IF EXISTS SP_UpdateData;
   DELIMITER //
   CREATE PROCEDURE SP_UpdateData (OLID VARCHAR(38), NLID VARCHAR(38), TableName VARCHAR(38))
   BEGIN
     SET @tablename=TableName;
     SET @tmptablename=CONCAT(@tablename,'_tmp');

     #删除临时表, 不加这句下次执行时会报错,提示临时表已存在

     SET @sqlcmd=CONCAT('DROP TEMPORARY TABLE IF EXISTS ', @tmptablename); 
     PREPARE stmt FROM @sqlcmd;
     EXECUTE stmt;
     DEALLOCATE PREPARE stmt;
    

     #创建临时表
     SET @sqlcmd=CONCAT('CREATE TEMPORARY TABLE ', @tmptablename);
     SET @sqlcmd=CONCAT(@sqlcmd, ' SELECT * FROM ');
     SET @sqlcmd=CONCAT(CONCAT(@sqlcmd, @tablename), ' WHERE 1=0');
     PREPARE stmt FROM @sqlcmd;
     EXECUTE stmt;
     DEALLOCATE PREPARE stmt;
    

     #将来源数据插入临时表
     SET @sqlcmd=CONCAT('INSERT INTO ', @tmptablename);
     SET @sqlcmd=CONCAT(@sqlcmd, ' SELECT * FROM ');
     SET @sqlcmd=CONCAT(@sqlcmd, @tablename);
     SET @sqlcmd=CONCAT(@sqlcmd, ' WHERE LID=?');
     SET @a=OLID;
     PREPARE stmt FROM @sqlcmd;
     EXECUTE stmt USING @a;
         DEALLOCATE PREPARE stmt;

    #刷新临时表的外键为NLID

     SET @sqlcmd=CONCAT(CONCAT('UPDATE ', @tmptablename), ' SET MID=UUID(), LID=?');
     SET @b=NLID;
         PREPARE stmt FROM @sqlcmd;
     EXECUTE stmt USING @b;
     DEALLOCATE PREPARE stmt;

     #临时表中数据插入回原表

     SET @sqlcmd=CONCAT(CONCAT(CONCAT('INSERT INTO ', @tablename), ' SELECT * FROM '), @tmptablename);
     PREPARE stmt FROM @sqlcmd;
     EXECUTE stmt;
     DEALLOCATE PREPARE stmt;
  END //
  DELIMITER ;

  (2)查询树形结构子节点

   #遍历父节点ParentMID下的所有树节点, 开始时想参考SQL Server中的写法,利用临时表, 但是测试时报错,原因见8

#因为对MySQL不熟悉,干脆直接新建了表,当临时表用, 实现功能先。

  DROP PROCEDURE IF EXISTS SP_GetChildrenNodes;
  DELIMITER //
  CREATE PROCEDURE SP_GetChildrenNodes (ParentMID VARCHAR(50), Maker VARCHAR(20), IncludeRoot INT) 
  BEGIN
    DELETE FROM A_tmp WHERE cMaker=Maker;
    INSERT INTO A_Tmp (MID,cMaker) SELECT ParentMID, Maker;
    WHILE EXISTS (SELECT MID FROM A WHERE PreMID IN (SELECT MID FROM A_tmp WHERE cMaker=Maker) AND MID NOT IN (SELECT MID FROM A_tmp WHERE cMaker=Maker)) DO
      INSERT INTO A_tmp (MID,cMaker) SELECT MID,Maker FROM A WHERE PreMID IN (SELECT MID FROM A_tmp WHERE cMaker=Maker) AND MID NOT IN (SELECT MID FROM A_tmp WHERE cMaker=Maker);
    END WHILE;
    IF IncludeRoot = 1 THEN #查询结果包含父节点
      SELECT * FROM A WHERE MID IN (SELECT MID FROM A_tmp WHERE cMaker=Maker) ORDER BY PreMID,iSerialNO;
    ELSE
      SELECT * FROM A WHERE MID IN (SELECT MID FROM A_tmp WHERE MID<>ParentMID AND cMaker=Maker) ORDER BY PreMID,iSerialNo;
    END IF;
  END; //
  DELIMITER ;

  5. SQL函数的区别

  (1) select *   from A where convert(nvarchar(10),tMakeDate,121)>='2015-05-08'

  ->SELECT * from A WHERE DATE_FORMAT(tMakeDate, '%Y-%m-%d')>='2015-05-08'

  (2) select * from A where isnull(cMaker, '')<>''

  -> SELECT * from A where IFNULL(cAuditMan,'')<>''

  (3) select newid()

  ->SELECT UUID()

    select getdate()

  ->SELECT NOW()

  (4) update a set a.字段1=b.字段2 from 表A  a, 表B  b where a.MID='1'

  ->UPDATE 表A  a, 表B  b SET a.字段1=b.字段2 WHERE a.MID='1' AND b.MID='2'

  (5) select top 10 * from A

  -> SELECT * FROM A LIMIT 10

  (6) select convert(nvarchar(10),getdate(),121) as Date1, convert(nvarchar(10),getdate()-2,121) as Date2

  ->SELECT DATE_FORMAT(NOW(),'%Y-%m-%d') as Date1, DATE_FORMAT(DATE_SUB(NOW(), INTERVAL 2 DAY), '%Y-%m-%d') as Date2

  (7) insert into A(MID,iType) select newid(), 1 where not exists(select 1 from A where iType=1)

  ->INSERT INTO A(MID, iType) SELECT UUID(), 1 FROM DUAL WHERE NOT EXISTS (SELECT 1 FROM A WHERE iType=1)  #Dual虚拟表

  (8)where (4

  ->WHERE(4

  (9)添加字段 并指定编码格式

  alter table A add cNewFldName varchar(20) CHARACTER SET utf8 DEFAULT null;

  6. 设置MYSQL为UTF8编码

  修改my.ini配置文件,参考:http://blog.csdn.net/red4711/article/details/6007248

  

  (1)在 [mysqld]块中加上以下内容:

  default-character-set = utf8

  character_set_server = utf8

  注意:如果此标签下已经存在“default-character-set=GBK”类似的内容,只需修改即可。

  (2)在 [mysql]块中加上一行

  default-character-set = utf8

  (3)在 [mysql.server]块中加上一行

  default-character-set = utf8

  (4)在 [mysqld_safe]块中加上一行

  default-character-set = utf8

  (5)在 [client]块中加上一行

  default-character-set = utf8

  (6)重启MySql服务

  修改My.ini后,重启MySQL服务,上截图中的latin1会调整为utf8, 如下图所示:

  

  7. MYSQL中不支持匿名块,也就是说过程性语句IF,THEN必须放在存储过程中执行。

  MS SQL Server中类似先判断 if exists (select 1 from A where MID='1')  再执行其它操作的语句在MySQL中要作调整。

  8. MySQL中不允许在同一语句中对临时表多次引用

  9. 存储过程中利用 exec 执行动态语句

  SQL Server中能方便的将表名、字段名、(查询)条件等组合成SQL语句,利用exec、sp_executesql 执行动态语句,MySQL中区别不小:

  MSSQLServer: //同一表中复制新增数据 

    set @mysql='select * into #temp from '+ @TableName+' where 1=0'
      set @mysql=@mysql+' insert into #temp select * from '+@TableName+' where LID='''+@OLID+''''
      set @mysql=@mysql+' update #temp set MID=newid() ,LID='''+@NLID+''''
      set @mysql=@mysql+' insert into '+ @TableName+' select * from #temp '
      exec(@mysql)

   MySQL:

  参考:http://blog.csdn.net/moshuchao/article/details/2153342

  从MySQL 5.0 开始,支持了一个全新的SQL句法:
  PREPARE stmt_name FROM preparable_stmt;
  EXECUTE stmt_name [USING @var_name [, @var_name] ...];
  {DEALLOCATE | DROP} PREPARE stmt_name;

  (1)将表名作参数

  

  测试时本想用下述思路:

  a: SET @sqlcmd='select * from ?';

   b: SET @tablename='test';

   c: PREPARE stmt FROM @sqlcmd;

   d: EXECUTE stmt USING @tablename;

   e: DEALLOCATE PREPARE stmt;

  在命令行中执行到c时,报错:

  ERROR 1064(42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '?' at line 1

  (2)将表名、查询字段、查询字段值 作为参数

  

  实际存储过程见4.(1)同表复制数据

  10. MYSQL无法对字段设置类似MSSQLServer中newid()默认值。

  代码中涉及操作数据库的地方已基本改完,接下来就要考虑数据库升级、备份、还原、数据文件安全等问题了,牵一发动全身,改点东西真是不容易……

  2015年7月8日 09:48:33

  11. 昨晚改了几个日期字段的类型timestamp改成datetime, 当时没注意,把允许空的选项给去掉了,今早来运行程序,报错,提示: 

  数据提供程序或其他服务返回 E_FAIL 状态。

  重新将字段设置为允许空,问题解决。

MS SQL Server2000转换成MySQL的更多相关文章

  1. 怎么将oracle的sql文件转换成mysql的sql文件

    怎么将sql文件导入PowerDesigner中的方法(将oracle的sql文件转换成mysql的sql文件)呢? 怎么将xx.sql文件的数据库结构导入powerdesigner 的方法呢? 现讲 ...

  2. 怎么将oracle的sql文件转换成mysql的sql文件-- 费元星

    http://jingyan.baidu.com/article/ca41422fe01f251eaf99ed6e.html

  3. SQLServer数据库转换成MySQL数据库

    由于工作需要,系统原先的SQLServer数据库要转换成MYSQL数据库,所以这两天就一直在查阅这方面的资料.最开始,我尝试从SQLServer中导出SQL文件,然后导入到MYSQL数据库中,发现报错 ...

  4. hibernate sql查询转换成VO返回list

    hibernate sql查询转换成VO @Override public List<FenxiVo> getTuanDuiFenxiList(FenxiVo FenxiVo,Intege ...

  5. Mysql转换成SqlServer数据库,以及SqlServer转换成Mysql数据库

    Windows XP sp2 MS SQL Server 2OOO sp1 MySql 5.0.41 1:MSSQLServer数据库导入到MySql数据库 步骤: 1.安装mysql数据库的ODBC ...

  6. 【HIVE】sql语句转换成mapreduce

    1.hive是什么? 2.MapReduce框架实现SQL基本操作的原理是什么? 3.Hive怎样实现SQL的词法和语法解析? 连接:http://www.aboutyun.com/thread-20 ...

  7. MS SQL SERVER数据导入MySQL

    1.sql server导出到xls,再导入到mysql中.亲测,单表数据量到百万以后,导出异常,可能由其它原因导致,没细纠.此种方式需要来回倒腾数据,稍繁琐. 2.采用kettle第三方的ETL工具 ...

  8. SQL 汉字转换成拼音首字母 首字母查

    -- ============================================= -- 功能:汉字转换成拼音首字母 首字母查 -- ========================== ...

  9. 将Microsoft SQL Server 2000数据库转换成MySQL数据库

    1. 下载并安装MyODBC.(如果是XP请下载5.3的旧版本,8.x的新版本运行有问题) 2. 创建一个空的MySQL数据库. 3. 在Windows >> 控制面板 >> ...

随机推荐

  1. Hadoop中RPC协议小例子报错java.lang.reflect.UndeclaredThrowableException解决方法

    最近在学习传智播客吴超老师的Hadoop视频,里面他在讲解RPC通信原理的过程中给了一个RPC的小例子,但是自己编写的过程中遇到一个小错误,整理如下: log4j:WARN No appenders ...

  2. Facebook力推导航库:React Navigation使用详解

    本文来自Songlcy投稿:文章地址:http://blog.csdn.net/u013718120/article/details/72357698 一.开源库介绍 今年1月份,新开源的react- ...

  3. centos 6的LAMP一键安装包(可选择/升级版本)

    安装步骤 事前准备(安装 wget.screen.unzip,创建 screen 会话) yum -y install wget screen git git clone 并赋予脚本执行权限 git ...

  4. jquery中ajax回调函数使用this

    今天在写ajax请求的的时候success中代码老是不能正常执行,找了半天的原因,代码如下: 1 $.ajax({type: 'GET', 2 url: url, 3 data: oData, 4 s ...

  5. OCR训练数据生成方法

    有的时候我们训练网络的时候,数据集在收集的过程中由于种种原因导致图像收集的不完整,比如某些种类很少,或者没有,这个时候我们就可以考虑自己生成数据集. 这个和data augmentation还不太一样 ...

  6. bower安装使用、git安装、node安装、weui安装开发

    bower安装使用以及git安装 bower需要:node 和 git 1.Git安装:(选择第二项:Use Git from the Windows Command Prompt)2.node安装: ...

  7. 解决org.apache.hadoop.io.nativeio.NativeIO$Windows.access0(Ljava/lang/String;I)Z

    这个问题来的有点莫名奇妙,之前我的hadoop运行一直是正常的,某一天开始运行Mapreduce就报这个错. 试过很多种方法都没有用,比如 1.path环境变量2.Hadoop bin目录下hadoo ...

  8. Java_io__BIO_NIO_AIO

    1. http://stevex.blog.51cto.com/4300375/1284437 http://www.cnblogs.com/zhuYears/archive/2012/09/28/2 ...

  9. 关于Android中根据ID名动态获取资源的两个方法

    在开发中, 我们习惯了类似下面这种方式去实现引用资源: context.getResources().getDrawable(R.drawable.flower); 但是,当我们提前知道这个资源的id ...

  10. 腾讯开源的Android UI框架——QMUI Android

    各位同学,早上好,我是你们的老朋友D_clock爱吃葱花,前些天忙着发版本,最近也在看各种各样的新知识,有好多东西想写啊啊啊啊啊.嗯,先冷静捋一下,卖个关子.扯回正题,今天继续为大家推荐一个Githu ...