PDA

View Full Version : [SQL] Trasporre Tabella in Oracle


holymind
07-09-2009, 11:31
Ciao a tutti.
Ho l'esigenza di trasporre una tabella in oracle, ossia passare da una tabella chiave valore ad una tabella normale.

Faccio l'esempio esplicativo.
Passare da una tabella di questo tipo

Id Chiave Valore
1 Nome Pinco
1 Cognome Pallino
1 Eta 15
1 Citta Milano
1 Nome Tizio
1 Cognome Rossi
1 Eta 30
1 Citta Roma


Alla tabella
Id Nome Cognome Eta Citta
1 Pinco Pallino 15 Milano
2 Tizio Rossi 30 Roma

Grazie in anticipo

morskott
07-09-2009, 12:02
Se vuoi trasformare il primo tipo di tabella nel secondo ti crei tramite una create table una tabella con le colonne che vuoi e tramite un programmetto metti i dati della prima nella seconda, poi cancelli la prima tabella, un esempio del trasferimento dei dati in java

public static void daAaB(Connection conn) throws Exception{
class Temp{
Map<String,String> vals=new HashMap<String,String>();
}
Map<Integer,Temp> tmp=new HashMap<Integer,Temp>();
Statement stat=conn.createStatement();
ResultSet rs=stat.executeQuery("select * from A");
while (rs.next()){
int id=rs.getInt("ID");
Temp info=tmp.get(id);
if (info==null){
info=new Temp();
tmp.put(id,info);
}
temp.vals.put(rs.getString("Chiave"),rs.getString("Valore"));
}
rs.close();
Set<Integer> keySet=tmp.keySet();
for (Integer id:keySet){
Temp vals=tmp.get(id);
String metas="";
String values="";
Set<String> inks=vals.vals.keySet();
for (String chiave:inks){
metas+=chiave+",";
values+="\'+vals.vals.get(chiave)+"\',";
}
metas="ID,"+metas.subset(0,metas.length()-1);
values=String.valueOf(id)+","+values.subset(0,values.length()-1);
st.executeUpdate("insert into B("+metas+") values ("+values+")");
}
st.close();
}
č codice scritto in quattro e quattr'otto, di sicuro non il pių efficiente e non sono al 100% sicuro sulla correttezza

gugoXX
07-09-2009, 23:38
Io proverei cosi'


CREATE TABLE result AS
SELECT ID,
(SELECT Valore FROM src WHERE src.ID=out.ID AND src.Chiave='Nome') as Nome,
(SELECT Valore FROM src WHERE src.ID=out.ID AND src.Chiave='Cognome') as Cognome,
(SELECT Valore FROM src WHERE src.ID=out.ID AND src.Chiave='Eta') as Eta,
(SELECT Valore FROM src WHERE src.ID=out.ID AND src.Chiave='Citta') as Citta
FROM
(SELECT DISTINCT ID FROM src) out;