首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在Bash例程中循环执行mysql的结果集。

在Bash例程中循环执行mysql的结果集。
EN

Stack Overflow用户
提问于 2020-02-17 07:46:49
回答 1查看 198关注 0票数 1

我想为我的每个例程创建特定的.sql文件。

代码语言:javascript
运行
复制
#!/bin/bash

 routine_names=$(mysql mydb  --execute="SELECT 
    *
FROM
    information_schema.routines
WHERE
    routine_type = 'PROCEDURE' OR routine_type ='FUNCTION'
        AND routine_schema = 'mydb';"|cut -f1)

for routine in "$routine_names"
do
    if [ -e "${routine}.sql" ]
     then
    echo "ok"
    else
     content_procedure=$(mysql mydb--execute="SHOW CREATE PROCEDURE $routine;")
     echo "$content_procedure" >> masoud.txt
   fi   
done 

我的routine_names变量是我的过程列表。就像这样:

代码语言:javascript
运行
复制
SP_ONE
SP_TWO
SP_THREE

我想循环这些结果。但我认为结果不是一个数组。因为routine变量包含所有内容。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-02-17 08:11:25

mysql mydb ...命令包装()命令

代码语言:javascript
运行
复制
 routine_names=($(mysql mydb  --execute="SELECT 
    *
FROM
    information_schema.routines
WHERE
    routine_type = 'PROCEDURE' OR routine_type ='FUNCTION'
        AND routine_schema = 'mydb';"|cut -f1))

我很好奇,从这里那里得到了这个想法。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60257939

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档