前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >mysql shell创建数据库_mysql怎么建立数据库

mysql shell创建数据库_mysql怎么建立数据库

作者头像
全栈程序员站长
发布于 2022-10-05 00:39:55
发布于 2022-10-05 00:39:55
86.3K0
举报

大家好,又见面了,我是你们的朋友全栈君。

#!/bin/sh

SHELL_NAME=GetTabStript.sh

/bin/rm -f CreateTable.sql

/bin/rm -f tmp.sql

##获取数据库用户名、密码、实例,属主,表名称列表信息;执行格式如下:

##指定表:sh GetTabStript.sh “dbrwdadm” “dbrwdadm” “chnrwd” “DBRWDADM” “DCUSTMSG SCHNKPI” “CreateTable.sql”

##所有表:sh GetTabStript.sh “dbrwdadm” “dbrwdadm” “chnrwd” “DBRWDADM” “” “CreateTable.sql”

v_dbstr={1}/{2}@

v_ower=${4}

v_tablist=${5}

v_tabscript=${6}

##数据库连接,查询建表、索引语句

fExpTab()

{

sqlplus -s ${v_dbstr}

set linesize 2000

set long 99999

set pagesize 0

set feedback off

execute dbms_metadata.set_transform_param(dbms_metadata.session_transform,’STORAGE’,false);

@./${1}

exit

eof

}

##判断v_tablist 是否为空,进而调用不同查询语句

if [ -n “${v_tablist}” ];

then

##查询指定表建表语句

for v_tab in $v_tablist

do

v_sqlcon=”

select dbms_metadata.get_ddl(U.OBJECT_TYPE,u.object_name) \”/\”

from USER_OBJECTS U

where USER = upper(‘${v_ower}’)

and U.OBJECT_TYPE IN(‘INDEX’,’TABLE’)

and u.object_name in upper(‘${v_tab}’);”

##将查询建表语句输出到临时sql脚本

echo “${v_sqlcon}”>>tmp.sql

##fExpTab “${v_sqlcon}”>>tabscript.tmp

done

else

##查询用户下所有表建表语句

v_sqlall=”

select dbms_metadata.get_ddl(U.OBJECT_TYPE,u.object_name) \” \”

from USER_OBJECTS U

where USER = upper(‘${v_ower}’)

and U.OBJECT_TYPE IN(‘INDEX’,’TABLE’)

order by U.OBJECT_TYPE desc;”

##将查询建表语句输出到临时sql脚本

echo “${v_sqlall}”>>tmp.sql

##fExpTab “${v_sqlall}”>>tabscript.tmp

fi

##调用数据库函数执行临时sql脚本,并生成临时建表脚本

fExpTab “tmp.sql”>>tabscript.tmp

##读取并规范临时脚本文件

##将临时脚本中的多余空行,替换为”/”,使之成为能直接被数据库调用的建表脚本

awk -v RS=’\r\n’ ‘gsub(/\n\n\n/,”\n/”)’ tabscript.tmp >>${v_tabscript}

rm -f tabscript.tmp tmp.sql

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月8日 下,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档