根据数据源类型选择不同的迁移方案
针对不同的数据源(如MySQL、Oracle等),可以使用不同的工具和方法进行迁移。例如,在使用Python迁移MySQL数据库时,可以使用pymysql和mysqldump库,而在迁移Oracle数据库时,则需要使用cx_Oracle库和exp工具。以下是基于Python的示例代码:
import pymysql import subprocess
import cx_Oracle
def migrate_mysql_table(source_conn, target_conn, table_name): # 建立源数据库连接 source_db = pymysql.connect(host='source_host', user='source_user', password='source_pwd', db='source_db')
# 建立目标数据库连接
target_db = pymysql.connect(host='target_host',
user='target_user',
password='target_pwd',
db='target_db')
# 选择需要迁移的表
source_cursor = source_db.cursor()
source_cursor.execute(f"SELECT * FROM {table_name}")
result = source_cursor.fetch_all()
# 插入目标表
target_cursor = target_db.cursor()
target_cursor.executemany(f"INSERT INTO {table_name} VALUES (%s)", result)
target_db.commit()
def migrate_oracle_table(source_conn, target_conn, table_name): # 建立源数据库连接 source_db = cx_Oracle.connect('source_user/source_pwd@source_host:source_port/source_sid')
# 建立目标数据库连接
target_db = cx_Oracle.connect('target_user/target_pwd@target_host:target_port/target_sid')
# 选择需要迁移的表
source_cursor = source_db.cursor()
source_cursor.execute(f"SELECT * FROM {table_name}")
result = source_cursor.fetchall()
# 插入目标表
target_cursor = target_db.cursor()
target_cursor.executemany(f"INSERT INTO {