Oracle
 sql >> Teknologi Basis Data >  >> RDS >> Oracle

Bandingkan dua catatan dan tunjukkan hanya perbedaannya

Berikut adalah pendekatan instrumen tumpul untuk masalah ini.

create or replace function col_diff
    ( p_empno_1 in emp.empno%type
      , p_empno_2 in emp.empno%type )
    return col_nt pipelined
is
    out_val col_t := new col_t(null, null, null);
    emp_rec1 emp%rowtype;
    emp_rec2 emp%rowtype;
begin
    select *
    into emp_rec1
    from emp
    where empno = p_empno_1;
    select *
    into emp_rec2
    from emp
    where empno = p_empno_2;

    if emp_rec1.ename != emp_rec2.ename
    then
        out_val.col_name := 'ENAME';
        out_val.old_val := emp_rec1.ename;
        out_val.new_val := emp_rec2.ename;
        pipe row (out_val); 
    end if;
    if emp_rec1.hiredate != emp_rec2.hiredate
    then
        out_val.col_name := 'HIREDATE';
        out_val.old_val := to_char(emp_rec1.hiredate, 'DD-MON-YYYY');
        out_val.new_val := to_char(emp_rec2.hiredate, 'DD-MON-YYYY');
        pipe row (out_val); 
    end if;
    return;
end;
/

Jadi, berdasarkan data pengujian ini...

SQL> select empno, ename, hiredate
  2  from emp
  3  where empno > 8100
  4  /

     EMPNO ENAME      HIREDATE
---------- ---------- ---------
      8101 PSMITH     03-DEC-10
      8102 PSMITH     02-JAN-11

SQL>

... kita mendapatkan output ini:

SQL> select * from table (col_diff(8101,8102))
  2  /

COL_NAME
------------------------------
OLD_VAL
-------------------------------------------------------------------
NEW_VAL
-------------------------------------------------------------------
HIREDATE
03-DEC-2010
02-JAN-2011


SQL>

Sekarang, pasti Anda menginginkan sesuatu yang tidak terlalu bertele-tele. Saya pikir dimungkinkan untuk melakukan sesuatu menggunakan SQL dinamis Metode 4 yang disempurnakan yang diperkenalkan pada 11g. Sayangnya, Anda mengatakan Anda menggunakan 10g.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Temukan Semua Nilai Non-Numerik dalam Kolom di Oracle

  2. Oracle - membandingkan nilai default kolom

  3. Fungsi NLS_CHARSET_ID() di Oracle

  4. Oracle mengabaikan kesalahan pengidentifikasi yang tidak valid di subquery

  5. Ekspresi Reguler dari format Tanggal tertentu