南浦电商网站建设,自媒体123网站,wordpress加入音乐,鞋子 东莞网站建设SQL*Plus Copy命令 问题描述 怎样在SQL*Plus中实现不同的表之间的数据复制#xff0c;不论是本地的还是远程的#xff1f; 问题分析 在SQL*Plus中的copy命令#xff0c;可以完成远程数据库、本地数据库或Oracle数据库与非Oracle数据库之间的数据复制。其性能与导入/导出相同…SQL*Plus Copy命令 问题描述 怎样在SQL*Plus中实现不同的表之间的数据复制不论是本地的还是远程的 问题分析 在SQL*Plus中的copy命令可以完成远程数据库、本地数据库或Oracle数据库与非Oracle数据库之间的数据复制。其性能与导入/导出相同。 copy的基本命令格式
copy {from source_database to destination_database}{append|create|insert|replace}destination_table[(column,column,column,...)]usingsource_select_statement
其中数据库连接使用如下格式: username/password\]connect_identifier 在数据复制时复制支持的数据类型为char、date、long、number、varchar2。 所示。
SQL*Plus Copy命令可在不同数据库之间以及同一个数据库内的不同模式的表之间复制数据。 从远程数据库复制数据到本地数据库。 从本地数据库默认复制数据到远程数据库。 从一个远程数据库复制数据到另一个远程数据库。 通常copy命令用于Oracle数据库与非Oracle数据库之间复制数据。如果在Oracle数据库之间复制数据应该使用create table as 和insert的SQL命令。 ?对目标表的控制方式有4种类型replace、create、insert和append。 replace子句指定了被创建的表名。如果目标表已存在则删除并用包含复制数据的表替代。若不存在则创建目标表。 使用create子句可避免覆盖已存在的表。若目标表已存在则copy报告一个错误若不存在则创建目标表。 insert插入数据到已存在的表。 将查询到的行插入到目标表如果目标表不存在copy返回错误。当使用insert时using子句必须为目标表的每个列选择对应的列。 append是将查询到的行插入到目标表。如果不存在则创建目标表并插入。 问题解答 首先应注意的是
1copy是SQL*Plus命令不是SQL命令在语句最后不必加分号
2由于多数copy命令比较长所以在分行时每行末尾必须有续行符(-)最后一行不加。 具体步骤如下。 步骤1使用using子句指定一个查询将其查询结果数据复制到本地数据库的当前模式下employee表中。例如
copy from hr/hrdrensh-replace employee-using select last_name,salary-from emp_details_view-where department_id30
步骤2使用create从一个远程数据库复制数据到本地数据库。
copy from hr/your_passwordbostondb-create empcopy-using select*from hr 步骤3为其他用户复制数据。
copy from hr/hrdbora-create job-using select*from renbs.jobs
以用户hr连接到数据库dbora将renbs模式的jobs表复制到当前本地数据库。 步骤4在同一个数据库中可将一个模式的表复制到另一个模式中。同样必须指定用户口令和数据库服务名。
copy from hr/passwordmydatabase-insert employee_copy2-using select * from employee_copy
步骤5在同一个远程数据库中复制表必须是关键字from和to中包含相同用户名和数据库服务名。
copy from hr/passworddaliandb-to hr/passworddaliandb-insert employee_copy2-using select * from employee_copy