網站首頁 編程語言 正文
環境
cat /etc/redhat-release
CentOS Linux release 7.5.1804 (Core)
[root@localhost ~]# uname -a
Linux localhost.localdomain 3.10.0-862.el7.x86_64 #1 SMP Fri Apr 20 16:44:24 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux
python -V
Python 2.7.5
安裝連接oracle的python包
pip install cx_Oracle==7.3
獲取oracle表信息
cat query_oracle.py
#!/usr/bin/env python
import cx_Oracle
import sys
import os
import csv
import traceback
file = open("oracle.txt", 'w').close()
user = "test"
passwd = "test"
listener = '10.0.2.15:1521/orcl'
conn = cx_Oracle.connect(user, passwd, listener)
cursor = conn.cursor()
sql = "select table_name from user_tables"
cursor.execute(sql)
LIST1=[]
while True:
row = cursor.fetchone()
if row == None:
break
for table in row:
#print table
LIST1.append(table)
LIST2=[]
for i in LIST1:
sql3 = "select COLUMN_NAME,DATA_TYPE,DATA_PRECISION,DATA_SCALE from cols WHERE TABLE_name=upper('%s')" %i
cursor.execute(sql3)
cursor.execute(sql3)
row3 = cursor.fetchall()
for data in row3:
#LIST2.append(i)
LIST2.extend(list(data))
LIST2.append(i)
f=open('oracle.txt','a+')
print >> f,LIST2
LIST2=[]
#f=open('test.txt','a+')
#select table_name,column_name,DATA_TYPE from cols WHERE TABLE_name=upper('student');
#select column_name,DATA_TYPE from cols WHERE TABLE_name=upper('student');
去掉多余部分
cat auto.sh
#!/bin/bash
#python query_oracle.py |tr "," ' '|tr "'" ' '|tr "[" " "|tr "]" " "
#>oracle.txt
>oracle_tables.txt
cat oracle.txt |tr "[],'" " "|sed "s#[ ][ ]*# #g"|sed 's/^[ \t]*//g' >> oracle_tables.txt
cat oracle_tables.txt
SNO NUMBER 19 0 SNAME VARCHAR2 None None SSEX VARCHAR2 None None SBIRTHDAY DATE None None SCLASS VARCHAR2 None None STUDENT DATE_DATE
SNO2 NUMBER 19 0 SNAME VARCHAR2 None None SSEX VARCHAR2 None None SBIRTHDAY DATE None None SCLASS VARCHAR2 None None STUDENT2 INPUT_TIME
SNO3 NUMBER 19 2 SNAME VARCHAR2 None None SSEX VARCHAR2 None None SBIRTHDAY DATE None None SCLASS VARCHAR2 None None STUDENT3 DATA_DATE
shell 腳本處理表信息文件
cat connect.sh
#!/bin/bash
#獲取臨時文件的行數
FILE_NUM=$(cat oracle_tables.txt |egrep -v '#|^$'|wc -l)
#清空自動創建連接器的腳本
>create-connect.sh
#循環臨時文件每一行
for i in `seq $FILE_NUM`
do
FILE_LINE=$(sed -n ${i}p oracle_tables.txt)
TABLE_NAME=$(echo ${FILE_LINE}|sed 's/[ \t]*$//g'|awk '{print $(NF-1)}')
COL_NUM=$(echo ${FILE_LINE}|sed 's/[ \t]*$//g'|awk -F "[ ]" '{print NF}')
REAL_COL_NUM=`expr $COL_NUM - 2`
#清空臨時文件
>${TABLE_NAME}.txt
>${TABLE_NAME}.sql
#循環臨時文件每行列名所在的列
for j in `seq 1 4 $REAL_COL_NUM`
do
k=`expr $j + 1`
m=`expr $j + 2`
n=`expr $j + 3`
COL_NAME=$(echo $FILE_LINE|cut -d " " -f${j})
COL_DATA_TYPE=$(echo $FILE_LINE|cut -d " " -f${k})
COL_DATA_PRECISION=$(echo $FILE_LINE|cut -d " " -f${m})
COL_DATA_SCALE=$(echo $FILE_LINE|cut -d " " -f${n})
#判斷列的數據類型是否是NUMBER
if [ "$COL_DATA_TYPE" = "NUMBER" ]
then
#循環拼接SQL查詢中的CAST(* AS *) AS *部分,追加到臨時文件中
echo "CAST($COL_NAME AS $COL_DATA_TYPE($COL_DATA_PRECISION,$COL_DATA_SCALE)) AS $COL_NAME" >> ${TABLE_NAME}.txt
else
#循環拼接SQL查詢中的列名部分,追加到臨時文件中
echo "$COL_NAME" >> ${TABLE_NAME}.txt
fi
done
#拼接完整的SQL語句,追加到臨時文件中
echo "select $(cat ${TABLE_NAME}.txt |tr "\n" ","|sed -e 's/,$/\n/') from $TABLE_NAME where $(sed -n ${i}p oracle_tables.txt|cut -d ' ' -f$COL_NUM)>=trunc(sysdate-2) and $(sed -n ${i}p oracle_tables.txt|cut -d ' ' -f$COL_NUM)<trunc(sysdate-1)" >> ${TABLE_NAME}.sql
#循環追加每個表對應的連接器到自動創建連接器的腳本中
cat >> create-connect.sh << EOF
curl -X POST http://localhost:8083/connectors -H "Content-Type: application/json" -d '{
"name": "jdbc_source_$TABLE_NAME",
"config": {
"connector.class": "io.confluent.connect.jdbc.JdbcSourceConnector",
"connection.url": "jdbc:oracle:thin:@{{ ORACLE_IP }}:{{ ORACLE_PORT }}:orcl",
"connection.user": "{{ ORACLE_USER }}",
"connection.password": "{{ ORACLE_PASSWD }}",
"topic.prefix": "YC_$TABLE_NAME",
"mode": "{{ CONNECT_MODE }}",
"query": "$(cat ${TABLE_NAME}.sql)"
}
}' >/dev/null 2>&1
EOF
done
說明:腳本中{{ 變量名 }}部分的內容是獲取ansible中的變量,這個腳本是和ansible結合使用的。
增強版處理表信息腳本
#!/bin/bash
#獲取臨時文件的行數
FILE_NUM=$(cat oracle_time_tables.txt |egrep -v '#|^$'|wc -l)
#清空創建連接器的腳本并追加echos函數
> create-jdbc-connect.sh
cat >> create-jdbc-connect.sh << EOF
#!/bin/bash
echos(){
case \$1 in
red) echo -e "\033[31m \$2 \033[0m";;
green) echo -e "\033[32m \$2 \033[0m";;
yellow) echo -e "\033[33m \$2 \033[0m";;
blue) echo -e "\033[34m \$2 \033[0m";;
purple) echo -e "\033[35m \$2 \033[0m";;
*) echo "\$2";;
esac
}
EOF
> create-jdbc-connect-time.sh
cat >> create-jdbc-connect-time.sh << EOF
#!/bin/bash
echos(){
case \$1 in
red) echo -e "\033[31m \$2 \033[0m";;
green) echo -e "\033[32m \$2 \033[0m";;
yellow) echo -e "\033[33m \$2 \033[0m";;
blue) echo -e "\033[34m \$2 \033[0m";;
purple) echo -e "\033[35m \$2 \033[0m";;
*) echo "\$2";;
esac
}
EOF
#創建表相關文件目錄
mkdir -p ./TABLE_TIME
#循環臨時文件每一行
for i in `seq $FILE_NUM`
do
FILE_LINE=$(sed -n ${i}p oracle_time_tables.txt)
TABLE_NAME=$(echo ${FILE_LINE}|sed 's/[ \t]*$//g'|awk '{print $(NF)}')
COL_NUM=$(echo ${FILE_LINE}|sed 's/[ \t]*$//g'|awk -F "[ ]" '{print NF}')
REAL_COL_NUM=`expr $COL_NUM - 2`
#清空臨時文件
>./TABLE_TIME/${TABLE_NAME}_time.txt
>./TABLE_TIME/${TABLE_NAME}_time.sql
>./TABLE_TIME/${TABLE_NAME}.sql
#循環臨時文件每行列名所在的列
for j in `seq 1 4 $REAL_COL_NUM`
do
k=`expr $j + 1`
m=`expr $j + 2`
n=`expr $j + 3`
COL_NAME=$(echo $FILE_LINE|cut -d " " -f${j})
COL_DATA_TYPE=$(echo $FILE_LINE|cut -d " " -f${k})
COL_DATA_PRECISION=$(echo $FILE_LINE|cut -d " " -f${m})
COL_DATA_SCALE=$(echo $FILE_LINE|cut -d " " -f${n})
#判斷列的數據類型是否是NUMBER
if [ "$COL_DATA_TYPE" = "NUMBER" ]
then
#循環拼接SQL查詢中的CAST(* AS *) AS *部分,追加到臨時文件中
echo "CAST($COL_NAME AS $COL_DATA_TYPE($COL_DATA_PRECISION,$COL_DATA_SCALE)) AS $COL_NAME" >> ./TABLE_TIME/${TABLE_NAME}_time.txt
else
#循環拼接SQL查詢中的列名部分,追加到臨時文件中
echo "$COL_NAME" >> ./TABLE_TIME/${TABLE_NAME}_time.txt
fi
#判斷是否存在hosts中定義的時間列,如果有就追加該列名進一個臨時文件中
TIME_COL=({{ TABLE_TIME_COL }})
for TIME in ${TIME_COL[@]}
do
if [ "$COL_NAME" = "$TIME" ]
then
echo "$COL_NAME" > ./TABLE_TIME/${TABLE_NAME}_TIME_COL.txt
fi
done
done
#拼接完整的SQL語句,追加到臨時文件中
if [ -f "./TABLE_TIME/${TABLE_NAME}_TIME_COL.txt" ]
then
#echo "select $(cat ./TABLE_TIME/${TABLE_NAME}.txt |tr "\n" ","|sed -e 's/,$/\n/') from {{ ORACLE_TABLES_USER }}.$TABLE_NAME where $(sed -n ${i}p oracle_tables.txt|cut -d ' ' -f$COL_NUM)>=trunc(sysdate-2) and $(sed -n ${i}p oracle_tables.txt|cut -d ' ' -f$COL_NUM)<trunc(sysdate-1)" >> ./TABLE_TIME/${TABLE_NAME}_time.sql
echo "select $(cat ./TABLE_TIME/${TABLE_NAME}_time.txt |tr "\n" ","|sed -e 's/,$/\n/') from {{ ORACLE_TABLES_USER }}.$TABLE_NAME where $(cat ./TABLE_TIME/${TABLE_NAME}_TIME_COL.txt)>=trunc(sysdate-2) and $(cat ./TABLE_TIME/${TABLE_NAME}_TIME_COL.txt)<trunc(sysdate-1)" >> ./TABLE_TIME/${TABLE_NAME}_time.sql
else
echo "select $(cat ./TABLE_TIME/${TABLE_NAME}_time.txt |tr "\n" ","|sed -e 's/,$/\n/') from {{ ORACLE_TABLES_USER }}.$TABLE_NAME" >> ./TABLE_TIME/${TABLE_NAME}.sql
fi
#循環追加每個表對應的連接器到自動創建連接器的腳本中
if [ -f "./TABLE_TIME/${TABLE_NAME}_TIME_COL.txt" ]
then
cat >> create-jdbc-connect-time.sh << EOF
#創建表 $TABLE_NAME 連接器的命令如下
curl -X POST http://localhost:8083/connectors -H "Content-Type: application/json" -d '{
"name": "jdbc_time_$TABLE_NAME",
"config": {
"connector.class": "io.confluent.connect.jdbc.JdbcSourceConnector",
"connection.url": "jdbc:oracle:thin:@{{ ORACLE_IP }}:{{ ORACLE_PORT }}:{{ ORACLE_SERVER_NAME }}",
"connection.user": "{{ ORACLE_USER }}",
"connection.password": "{{ ORACLE_PASSWD }}",
"topic.prefix": "YC_${TABLE_NAME}_INSERT",
"poll.interval.ms": "86400000",
"mode": "{{ CONNECT_MODE }}",
"numeric.mapping": "best_fit",
"query": "$(cat ./TABLE_TIME/${TABLE_NAME}_time.sql)"
}
}' >/dev/null 2>&1
#判斷連接器是否創建成功
if [ \$? -eq 0 ]
then
echos green "\$(date +"%F %H:%M:%S") 創建jdbc_time_${TABLE_NAME} 連接器成功"
else
echos red "\$(date +"%F %H:%M:%S") 創建jdbc_time_${TABLE_NAME} 連接器失敗"
fi
EOF
else
cat >> create-jdbc-connect.sh << EOF
#創建表 $TABLE_NAME 連接器的命令如下
curl -X POST http://localhost:8083/connectors -H "Content-Type: application/json" -d '{
"name": "jdbc_$TABLE_NAME",
"config": {
"connector.class": "io.confluent.connect.jdbc.JdbcSourceConnector",
"connection.url": "jdbc:oracle:thin:@{{ ORACLE_IP }}:{{ ORACLE_PORT }}:{{ ORACLE_SERVER_NAME }}",
"connection.user": "{{ ORACLE_USER }}",
"connection.password": "{{ ORACLE_PASSWD }}",
"topic.prefix": "YC_${TABLE_NAME}_INSERT",
"poll.interval.ms": "86400000",
"mode": "{{ CONNECT_MODE }}",
"numeric.mapping": "best_fit",
"query": "$(cat ./TABLE_TIME/${TABLE_NAME}.sql)"
}
}' >/dev/null 2>&1
#判斷連接器是否創建成功
if [ \$? -eq 0 ]
then
echos green "\$(date +"%F %H:%M:%S") 創建jdbc_${TABLE_NAME} 連接器成功"
else
echos red "\$(date +"%F %H:%M:%S") 創建jdbc_${TABLE_NAME} 連接器失敗"
fi
EOF
fi
done
原文鏈接:https://blog.csdn.net/weixin_40548182/article/details/118422058
相關推薦
- 2022-04-25 Python實現實時增量數據加載工具的解決方案_python
- 2022-04-01 關于python中if __name=‘__main__‘的理解
- 2022-09-13 Android實現屏幕旋轉四個方向準確監聽_Android
- 2024-01-30 深入理解Scrapy中XPath的`following-sibling`選擇器
- 2022-12-14 C#中委托和事件的區別詳解_C#教程
- 2022-05-29 Docker向數據卷Volume寫入數據_docker
- 2022-10-12 解決“WARNINGThe?remote?SSH?server?rejected?X11?forwa
- 2022-09-27 Kotlin靜態方法的使用淺析_Android
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支