sql >> Database >  >> RDS >> Oracle

Samenvoegen-instructie gebruiken voor enkele tabel

Gebruik SELECT ... FROM DUAL in de USING clausule om een ​​enkele rij met uw gegevens te genereren:

SQL Fiddle

Oracle 11g R2 Schema-instellingen :

create table student (
  sid int,
  name varchar(20),
  major varchar(10),
  gpa float,
  tutorid int,
  PRIMARY KEY (sid)
);

insert into student values(101,'Bill','CIS',3.45,102);
insert into student values(102,'Mary','CIS',3.1,null);
insert into student values(103,'Sue','Marketing',2.95,102);
insert into student values(104,'Tom','Finanace',3.5,106);
insert into student values(105,'Alex','CIS',2.75,106);
insert into student values(106,'Sam','Marketing',3.25,103);
insert into student values(107,'Joan','Finance',2.9,102);

Query 1 :

merge into student dst
using (
  SELECT 123 AS sid,
         'Rahul' AS name,
         'Temp' AS major
  FROM   DUAL
) src
on (src.major=dst.major)
when matched then
  update set name=src.name
when not matched then
  insert(SID,name,major) values ( src.sid, src.name, src.major )

Vraag 2 :

SELECT * FROM student

Resultaten :

| SID |  NAME |     MAJOR |    GPA | TUTORID |
|-----|-------|-----------|--------|---------|
| 101 |  Bill |       CIS |   3.45 |     102 |
| 102 |  Mary |       CIS |    3.1 |  (null) |
| 103 |   Sue | Marketing |   2.95 |     102 |
| 104 |   Tom |  Finanace |    3.5 |     106 |
| 105 |  Alex |       CIS |   2.75 |     106 |
| 106 |   Sam | Marketing |   3.25 |     103 |
| 107 |  Joan |   Finance |    2.9 |     102 |
| 123 | Rahul |      Temp | (null) |  (null) |



  1. Partitioneren resulteert in een lopende totalenquery

  2. CONTROLEER BEPERKING in Oracle SQL

  3. Hoe meerdere rijen te selecteren op primaire sleutel met meerdere kolommen in MySQL?

  4. Gegevens toevoegen aan een Cloud Firestore-database