按计划今天着手进行将后台数据库从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=CON