mysql导出单个存储过程_shell实现,将mysql每个存储过程导出为单个文件

#shell实现,将mysql中存储过程代码直接导出为文件

dbcn="mysql -h172.16.1.194 -uroot -p123456 ";

db=BCReport_Sync_Executor;

ii=0;

ct=`$dbcn -N -e " select count(1) from mysql.proc as p where 1=1 and p.db='$db' and p.type like 'P%';"`;

mkdir -p /chenenhui/$db

while true;

do

if [ $ii -lt $ct ]

then

p=$ii;

let ii++;

echo p=$p

echo ii=$ii

spname=`$dbcn -N -e " select p.name from mysql.proc as p where 1=1 and p.db='$db' and p.type like 'P%' limit $p,1;"`;

echo spname=$spname

sleep 0;

ss=`$dbcn -N -e "

SELECT

CONCAT(

'

DELIMI','TER ',REPEAT(CHAR(36),2),'

USE ',CHAR(96), p.db,CHAR(96),REPEAT(CHAR(36),2),'

DROP PROCEDURE IF EXISTS ',CHAR(96),p.name,CHAR(96), REPEAT(CHAR(36),2),'

CREATE DEFINER=',CHAR(96),

LEFT(DEFINER, -1+LOCATE('@',DEFINER)),

CHAR(96),'@',CHAR(96),

RIGHT(DEFINER,LENGTH(DEFINER)-LOCATE('@',DEFINER)),

CHAR(96)

,' PROCEDURE ',CHAR(96),p.name ,CHAR(96),'(',p.param_list,')

', p.body ,REPEAT(CHAR(36),2) ,'

DELIMI','TER ;

' ) AS sql_create

FROM mysql.proc AS p

WHERE 1=1

and p.db='$db'

and p.type LIKE 'P%'

AND p.name ='$spname'

;"

`

echo -e "$ss" > /chenenhui/$db/$spname.sql

echo $spname

else

echo '_while finished';

exit 0;

fi

done

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值