3_sp_data_migration_wcmmetatable.sql 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. DROP PROCEDURE IF EXISTS sp_data_migration_wcmmetatable;
  2. DELIMITER $$
  3. CREATE PROCEDURE sp_data_migration_wcmmetatable(IN citySuffix VARCHAR(20),
  4. IN prevTableInfoId BIGINT(20),
  5. IN prevDocId BIGINT(20),
  6. IN docIdOffset BIGINT(20),
  7. IN channelIdOffset BIGINT(20))
  8. BEGIN
  9. DECLARE isover INT DEFAULT 0;
  10. DECLARE f_TABLEINFOID INT DEFAULT 0;
  11. DECLARE f_TABLENAME VARCHAR(200) DEFAULT NULL;
  12. DECLARE cur CURSOR FOR
  13. SELECT
  14. TABLEINFOID,
  15. TABLENAME
  16. FROM xwcmtableinfo
  17. ORDER BY TABLEINFOID asc;
  18. DECLARE CONTINUE HANDLER FOR NOT FOUND SET isover = 1;
  19. OPEN cur;
  20. FETCH cur INTO
  21. f_TABLEINFOID,
  22. f_TABLENAME
  23. ;
  24. WHILE isover= 0 DO
  25. # 断点续传
  26. IF (f_TABLEINFOID > prevTableInfoId)
  27. THEN
  28. SET @metaTableExists = (SELECT count(1) from information_schema.tables where table_schema = 'trs_hycloud_iip' and table_name = concat('wcmmetatable', f_TABLENAME, citySuffix) );
  29. select concat('开始更新 :', @metaTableExists, '====:','wcmmetatable', f_TABLENAME, citySuffix) info;
  30. IF (@metaTableExists > 0)
  31. THEN
  32. select concat('开始更新 ', 'wcmmetatable', f_TABLENAME, citySuffix, '.MetaDataId & ChannelId') info;
  33. # 由于元数据表是动态生成的,执行存储过程前,需要提前将所有元数据表(结构+数据)直接复制至海云
  34. # 迁移后的元数据,其元数据ID不能和其他元数据表中的ID发生冲突,需要更改,因此有了以下SQL
  35. SET @update_sql = concat('UPDATE trs_hycloud_iip.wcmmetatable', f_TABLENAME, citySuffix,
  36. ' SET MetaDataId = MetaDataId + ', docIdOffset,
  37. ', ChannelId = ChannelId + ', channelIdOffset,
  38. ' WHERE MetaDataId > ', prevDocId);
  39. select concat('更新元数据sql: ', @update_sql ) info;
  40. prepare stmt from @update_sql;
  41. EXECUTE stmt;
  42. deallocate prepare stmt;
  43. if (prevTableInfoId = 0)
  44. then
  45. #设置ID的最大值
  46. set @max_sql = concat('SELECT ifnull(max(wcmmetatable', f_TABLENAME, citySuffix, 'ID), 0)into @meta_data_id from trs_hycloud_iip.wcmmetatable', f_TABLENAME, citySuffix);
  47. prepare stmt from @max_sql;
  48. EXECUTE stmt;
  49. deallocate prepare stmt;
  50. set @id_sql = concat('INSERT INTO trs_hycloud_iip.wcmid VALUES (','\'','wcmmetatable',
  51. f_TABLENAME, citySuffix, '\'',', ', @meta_data_id + 1,', 1, ','\'','wcmmetatable',f_TABLENAME, citySuffix,'ID','\'',');');
  52. select concat('插入wcmid元数据sql: ', @id_sql ) info;
  53. prepare stmt from @id_sql;
  54. EXECUTE stmt;
  55. deallocate prepare stmt;
  56. else
  57. #设置ID的最大值
  58. set @max_sql = concat('SELECT max(wcmmetatable', f_TABLENAME, citySuffix, 'ID) into @meta_data_id from trs_hycloud_iip.wcmmetatable', f_TABLENAME, citySuffix);
  59. prepare stmt from @max_sql;
  60. EXECUTE stmt;
  61. deallocate prepare stmt;
  62. set @id_sql = concat('UPDATE trs_hycloud_iip.wcmid SET NEXTID = ', @meta_data_id + 1,' where TABLENAME = ','\'','wcmmetatable',
  63. f_TABLENAME, citySuffix, '\'');
  64. prepare stmt from @id_sql;
  65. EXECUTE stmt;
  66. deallocate prepare stmt;
  67. end if ;
  68. SET @log_sql = build_migration_log_sql(concat('wcmmetatable', f_TABLENAME, citySuffix), @meta_data_id, now());
  69. prepare stmt from @log_sql;
  70. EXECUTE stmt;
  71. deallocate prepare stmt;
  72. select concat('完成更新 ', 'wcmmetatable', f_TABLENAME, citySuffix, '.MetaDataId & ChannelId') info;
  73. END IF ;
  74. END IF ;
  75. FETCH cur INTO
  76. f_TABLEINFOID,
  77. f_TABLENAME
  78. ;
  79. END WHILE;
  80. CLOSE cur;
  81. select CONCAT('sp_data_migration_wcmmetatable 执行完成') info;
  82. END $$
  83. DELIMITER ;