oracle-sql-在多个数据库执行相同sql

简介:

脚本 f_con_exe_sql.sh

################################################################################
#     sql:需要执行的Sql,根据具体sql代替
#     array_name2:数据库tns
#     实现:在不同厂区执行同一sql:比如需要在所有厂区建索引。
################################################################################
#${dbuser}/${pwd}@${db_ip}:${db_port}/${service_name}
#不同厂区:
array_name1=(
"厂区A"
"厂区B"
"厂区C"
"厂区D"
"厂区E"
"厂区F"
"厂区G"
"厂区H"
)
array_name2=(
userA/password@192.168.10.11:1521/orcl
userA/password@192.168.10.12:1521/orcl
userA/password@192.168.10.13:1521/orcl
userA/password@192.168.10.14:1521/orcl
userA/password@192.168.10.15:1521/orcl
userA/password@192.168.10.16:1521/orcl
userA/password@192.168.10.17:1521/orcl
userA/password@192.168.10.18:1521/orcl
)
#echo ${array_name[@]}
#echo "sqlplus / as sysdba"${array_name[1]}
#echo length=${#array_name[@]}


#需要执行的Sql

sql2="
select sysdate,instance_name from v\$instance;
"

sql="
set line 400
col SEGMENT_NAME for a25
col OWNER for a15
col TABLESPACE_NAME for a20
col PARTITION_NAME for a20
col BYTES for 9999999999999
col size_G for 999999999999
col DEGREE for a5
col TABLE_NAME for a20
col TABLE_OWNER for a15
col INDEX_NAME for a25

select owner,segment_name,partition_name,segment_type,tablespace_name,blocks,bytes,bytes/1024/1024/1024 G from dba_segments where segment_name=upper('table1');

create index idx_table1_n2 on table1(mdate) TABLESPACE tab_INX parallel 5 online;
alter index idx_table1_n2 noparallel;

SELECT i.owner,
       i.index_name,
       i.table_owner,
       i.table_name,
       i.tablespace_name,
       i.degree,
       i.status,
       i.last_analyzed,
       o.created,
       o.last_ddl_time
  FROM dba_indexes i, dba_objects o
 WHERE     i.index_name = o.object_name
       AND i.owner = o.owner
       AND i.index_name IN
              upper('idx_table1_n2');
"


CURRENT_DIR=$(cd `dirname $0`; pwd)
LOG_FILE=${CURRENT_DIR}/sql_exec_$(date +"%Y%m%d_%H%M%S").log.$dbuser
cat /dev/null > $LOG_FILE


display_all_db()
{
for(( i=0;i<${#array_name2[@]};i++)) do
#${#array_name[@]}获取数组长度用于循环
echo ${array_name1[i]}"-"${array_name2[i]#*@}| tee -a $LOG_FILE
done;
}

##----------------遍历所有厂区数据库,并执行sql语句
f_con_exe_sql()
{
echo "------------------------------"| tee -a $LOG_FILE
echo ""|tee -a $LOG_FILE
echo "遍历所有数据库,并执行sql语句.."| tee -a $LOG_FILE
for(( i=0;i<${#array_name2[@]};i++)) 
do
#${#array_name[@]}获取数组长度用于循环
echo "#${i} 数据库-" ${array_name1[i]}"-"${array_name2[i]#*@}| tee -a $LOG_FILE
echo " "|tee -a $LOG_FILE
echo "执行sql: $sql"| tee -a $LOG_FILE
#echo "sqlplus -S ${dbuser}/${pwd}${array_name2[i]}"
echo " "|tee -a $LOG_FILE
sqlplus -S ${array_name2[i]} <<EOF | tee -a $LOG_FILE
$sql
EOF
echo " "|tee -a $LOG_FILE
done;
echo "执行结果: $LOG_FILE " | tee -a  $LOG_FILE
}




#####--------------------------------man--------------------------------#######

echo "------------------------------"| tee -a $LOG_FILE
display_all_db

f_con_exe_sql
目录
相关文章
|
12天前
|
Oracle 关系型数据库 Linux
【赵渝强老师】Oracle数据库配置助手:DBCA
Oracle数据库配置助手(DBCA)是用于创建和配置Oracle数据库的工具,支持图形界面和静默执行模式。本文介绍了使用DBCA在Linux环境下创建数据库的完整步骤,包括选择数据库操作类型、配置存储与网络选项、设置管理密码等,并提供了界面截图与视频讲解,帮助用户快速掌握数据库创建流程。
185 93
|
1月前
|
SQL 机器学习/深度学习 人工智能
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
本文系统性地阐述了自然语言转SQL(NL2SQL) 技术如何让非技术背景的业务分析师实现数据自助查询,从而提升数据驱动决策的效率与准确性。
从“写SQL”到“聊数据”:NL2SQL如何用自然语言解锁数据库?
|
7天前
|
SQL 人工智能 Linux
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
112 5
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
|
6天前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
|
6天前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
24天前
|
SQL Oracle 关系型数据库
Oracle数据库创建表空间和索引的SQL语法示例
以上SQL语法提供了一种标准方式去组织Oracle数据库内部结构,并且通过合理使用可以显著改善查询速度及整体性能。需要注意,在实际应用过程当中应该根据具体业务需求、系统资源状况以及预期目标去合理规划并调整参数设置以达到最佳效果。
89 8
|
28天前
|
SQL 人工智能 Java
用 LangChain4j+Ollama 打造 Text-to-SQL AI Agent,数据库想问就问
本文介绍了如何利用AI技术简化SQL查询操作,让不懂技术的用户也能轻松从数据库中获取信息。通过本地部署PostgreSQL数据库和Ollama模型,结合Java代码,实现将自然语言问题自动转换为SQL查询,并将结果以易懂的方式呈现。整个流程简单直观,适合初学者动手实践,同时也展示了AI在数据查询中的潜力与局限。
189 8
|
1月前
|
SQL 人工智能 Linux
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC0 发布 - 从本地到云端的 AI 就绪企业数据库
122 5
|
12天前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
|
27天前
|
安全 关系型数据库 MySQL
MySQL安全最佳实践:保护你的数据库
本文深入探讨了MySQL数据库的安全防护体系,涵盖认证安全、访问控制、网络安全、数据加密、审计监控、备份恢复、操作系统安全、应急响应等多个方面。通过具体配置示例,为企业提供了一套全面的安全实践方案,帮助强化数据库安全,防止数据泄露和未授权访问,保障企业数据资产安全。

推荐镜像

更多