|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Bannato
Iscritto dal: Aug 2004
Messaggi: 180
|
[SQL] Trasporre Tabella in Oracle
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 |
![]() |
![]() |
![]() |
#2 |
Member
Iscritto dal: Jul 2005
Messaggi: 291
|
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
Codice:
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(); }
__________________
CPU: Intel Core 2 Quad Q6600 - Mobo: Asus P5E - RAM:4x2GB DDR2 - sk video: Power Color ATI Radeon HD3870 - HD:Western Digital 750GB |
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Io proverei cosi'
Codice:
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;
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 18:20.