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

Butuh bantuan untuk menyimpan nilai dari tiga kolom

Katakanlah Anda ingin memasukkan data ke dalam tabel seperti:

create table allEmailTable  (id number, mail varchar2(100))

Dengan asumsi Anda sudah memiliki kueri yang memberikan hasil tersebut, Anda mungkin perlu:

insert into allEmailTable(id, mail)
with yourQuery(ID, client_p_email, client_s_email, customer_mail) as (
  select 703        , 'example@sqldat.com'           ,'example@sqldat.com'   , 'example@sqldat.com' from dual union all                                   
  select 623        , 'example@sqldat.com'         ,'example@sqldat.com'   ,  'example@sqldat.com' from dual union all                                      
  select 965        , 'example@sqldat.com'      ,'example@sqldat.com',  'example@sqldat.com' from dual union all                                        
  select 270        , 'example@sqldat.com'      ,'example@sqldat.com',  'example@sqldat.com' from dual union all                                         
  select 719        , 'example@sqldat.com'        ,'example@sqldat.com'   ,  'example@sqldat.com' from dual
)
select distinct ID, mail
from (
      select id, client_p_email as mail from yourQuery UNION
      select id, client_s_email         from yourQuery UNION
      select id, customer_mail          from yourQuery 
     )

Hasilnya:

SQL> select * from allEmailTable;

        ID MAIL
---------- --------------------
       270 example@sqldat.com
       270 example@sqldat.com
       270 example@sqldat.com
       623 example@sqldat.com
       623 example@sqldat.com
       703 example@sqldat.com
       703 example@sqldat.com
       703 example@sqldat.com
       719 example@sqldat.com
       719 example@sqldat.com
       719 example@sqldat.com
       965 example@sqldat.com

12 rows selected.

Permintaan Anda akan menjadi:

insert into allEmailTable(id, mail)
with yourQuery(ID, client_p_email, client_s_email, customer_mail) as (
  SELECT DISTINCT 
                    clt.id,
                    clt.client_p_email,
                    clt.client_s_email,
                    cus.customer_mail
  from  client clt,
         customers cus
where clt.id=cus.id
)
select distinct ID, mail
from (
      select id, client_p_email as mail from yourQuery UNION
      select id, client_s_email         from yourQuery UNION
      select id, customer_mail          from yourQuery 
     )



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Arti dari byte dump(systimestamp) Oracle

  2. perbedaan oracle mysql postgreSQL

  3. Kelas Pool Koneksi Oracle

  4. Oracle:ORA-12154:Masalah TNS:Excel 64-bit/Windows 10 64-bit

  5. Tidak ada tanggapan untuk memperbarui permintaan di Oracle