首页 > 数据库技术 > 详细

Mysql——查询语句备份

时间:2020-10-13 21:16:48      阅读:37      评论:0      收藏:0      [点我收藏+]

    echo "++++++ modify log_uid start ++++++"

    mysql -h$targetIp -uroot codex_log_operation -Bse "show tables;" \

    | xargs -I "{}" mysql -h$targetIp -uroot codex_log_operation -e \

    "alter table {} modify log_uid varchar(128) NOT NULL; \

     alter table {} modify account_id bigint(64); \

     select concat(server_id, ‘_‘, log_uid) from {} limit 0;\

     update {} set  log_uid = concat(server_id, ‘_‘, log_uid) where length(0+log_uid)=length(log_uid);"

    echo "++++++ modify log_uid end ++++++"

 

 

 

 

select "重置id...";

drop procedure if exists `resetId`;

delimiter $$

create procedure  resetId(In targetTabName varchar(200))

begin

select targetTabName, @baseId;

 

set @sqlStr=CONCAT(‘delete from  ‘, targetTabName,  ‘ where roleId not in (select id from role)‘);

        PREPARE stmt from @sqlStr;

        EXECUTE stmt;

        DEALLOCATE PREPARE stmt;

 

set @sqlStr=CONCAT(‘update ‘, targetTabName, ‘ set id= id%(1<<42) +‘, @baseId, ‘, roleId= roleId%(1<<42) +‘, @baseId);

PREPARE stmt from @sqlStr;

EXECUTE stmt;

DEALLOCATE PREPARE stmt;

 

commit;

end$$

delimiter ;

 

SET @baseId=0;

select id, (id>>47)%(1<<11)%100, (id>>47)%(1<<11), id%(1<<42), @baseId:=(id-id%(1<<42)) from server limit 1;

select @baseId;

 

call resetId(‘activity_cat_usersave‘);

 

 

 

Mysql——查询语句备份

原文:https://www.cnblogs.com/xingchong/p/13810667.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!