我想以行的形式将一个表的所有列数据插入到另一个表中

Posted

技术标签:

【中文标题】我想以行的形式将一个表的所有列数据插入到另一个表中【英文标题】:I want to insert all columns data of an table in to another table in form of rows 【发布时间】:2020-03-06 09:23:16 【问题描述】:

-- 创建表

create table RADIOLOGY.TEST_DATA
(
  EMP_ID         VARCHAR2(100),
  EMP_NAME       VARCHAR2(500),
  EMP_CONTACT_NO VARCHAR2(500),
  EMP_ADDRESS    VARCHAR2(500),
  EMP_GENDER     VARCHAR2(500)
);

表格数据的格式为

1   JOHN    03000000    LONDON  MALE

我想输出为

EMP_ID         1
EMP_NAME       JOHN
EMP_CONTACT_NO 03000000
EMP_ADDRESS    LONDON
EMP_GENDER     MALE

【问题讨论】:

【参考方案1】:

您可以使用unpivot 将行数据转换为列数据:

select * 
  from test_data  
unpivot include nulls
( val for col in (emp_id, emp_name, emp_contact_no, emp_address, emp_gender ) ) 

Demo

【讨论】:

感谢 Barbaros Özhan,但我们可以在 in 子句之后使用 select *。因为我想要一个动态解决方案,所以我只想给出一个表格,并且该表格的所有列都应该按行排序。 不客气@gohar,使用sql是不可能的。【参考方案2】:

你的问题是:

我想将一个表的所有列数据以行的形式插入到另一个表中

这是什么意思?完全没有意义。原因如下:当我看到它时,我首先想到的是print_table 程序。我不记得谁是原作者(我不是);是问汤姆还是其他人,我真的不知道,对此我深表歉意。

这里是:

SQL> set serveroutput on
SQL> create or replace procedure print_table (p_query in varchar2)
  2     authid current_user
  3  is
  4     l_thecursor     integer default dbms_sql.open_cursor;
  5     l_columnvalue   varchar2 (4000);
  6     l_status        integer;
  7     l_desctbl       dbms_sql.desc_tab;
  8     l_colcnt        number;
  9  begin
 10     execute immediate 'alter session set
 11          nls_date_format=''dd.mm.yyyy hh24:mi:ss'' ';
 12
 13     dbms_sql.parse (l_thecursor, p_query, dbms_sql.native);
 14     dbms_sql.describe_columns (l_thecursor, l_colcnt, l_desctbl);
 15
 16     for i in 1 .. l_colcnt
 17     loop
 18        dbms_sql.define_column (l_thecursor,
 19                                i,
 20                                l_columnvalue,
 21                                4000);
 22     end loop;
 23
 24     l_status := dbms_sql.execute (l_thecursor);
 25
 26     while (dbms_sql.fetch_rows (l_thecursor) > 0)
 27     loop
 28        for i in 1 .. l_colcnt
 29        loop
 30           dbms_sql.column_value (l_thecursor, i, l_columnvalue);
 31           dbms_output.
 32            put_line (
 33              rpad (l_desctbl (i).col_name, 30) || ': ' || l_columnvalue);
 34        end loop;
 35
 36        dbms_output.put_line ('-----------------');
 37     end loop;
 38
 39  end;
 40  /

Procedure created.

它有什么作用?以您想要的格式呈现数据:

SQL> exec print_table('select * from emp where deptno = 30');
EMPNO                         : 7499
ENAME                         : ALLEN
JOB                           : SALESMAN
MGR                           : 7698
HIREDATE                      : 20.02.1981 00:00:00
SAL                           : 1600
COMM                          : 300
DEPTNO                        : 30
-----------------
EMPNO                         : 7521
ENAME                         : WARD
JOB                           : SALESMAN
MGR                           : 7698
HIREDATE                      : 22.02.1981 00:00:00
SAL                           : 1250
COMM                          : 500
DEPTNO                        : 30
-----------------
EMPNO                         : 7654
ENAME                         : MARTIN
JOB                           : SALESMAN
MGR                           : 7698
HIREDATE                      : 28.09.1981 00:00:00
SAL                           : 1250
COMM                          : 1400
DEPTNO                        : 30
<snip>

现在,回到“没有意义”:您打算如何将类似的东西插入另一个表?那张“另一张桌子”是什么样子的?它是否有(最多)1000 列(这是/曾经是限制),例如每个员工将被插入一列?我从未见过这样的数据模型。你会如何使用它?呈现给最终用户?老实说,不知道,我一点也不喜欢。

如果我误解了问题,请解释一下。

【讨论】:

不客气。我知道它有效,但我不知道你会用它做什么。希望你能做到。

以上是关于我想以行的形式将一个表的所有列数据插入到另一个表中的主要内容,如果未能解决你的问题,请参考以下文章

MySQL 中怎么把数据库表的一列置空?

动态SQL从表中执行大量行

如何将一个数据库中的一个表复制到另一个数据库中去

插入带有列的命令[重复]

如何在 OpenOffice 中将一列单元格从一张表插入到另一张表的单个单元格中?

如何将一个表的查询结果插入到另一个表中?