Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-06-2008, 15:12   #1
Redvex
Senior Member
 
L'Avatar di Redvex
 
Iscritto dal: Apr 2002
Città: Nosgoth
Messaggi: 16899
[SQL] Scrivere meglio le mie query

Sto facendo un programma in java/jsf/jsp utilizzando mysql come dbms; ora nel get di una variabile eseguo queste 3 query:
Codice PHP:
public String getNome_matr() {
        
sql ="SELECT MAX(id) FROM post";
        
ResultSet rs sqlCommandBean.executeQuery(sql);
        try{
            
rs.next();
            
this.id rs.getInt("MAX(id)");
        }catch (
Exception e){}
        
sql="SELECT matr_dipendente FROM inserisce WHERE id_post='"+this.id+"'";
        
ResultSet rs1 sqlCommandBean.executeQuery(sql);
        try{
            
rs1.next();
          
matr_post rs1.getInt("matr_dipendente");  
        }catch (
Exception e){}
        
sql ="SELECT nome FROM dipendente WHERE matricola='"+matr_post+"'";
        
ResultSet rs2 sqlCommandBean.executeQuery(sql);
        try{
            
rs2.next();
            
nome_matrrs2.getString("nome");
        }catch(
Exception e){}
        return 
nome_matr;
    } 
Come posso concentrare queste 3 query per avere solo 1 resultset?
Avendo delle buone prestazioni magari
__________________
Redvex è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2008, 15:46   #2
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Potresti provare a fare una union

Codice:
SELECT MAX(id),'query1' as tabella FROM post
union all
SELECT matr_dipendente,'query2' FROM inserisce WHERE id_post = x
union all
SELECT nome,'query3' FROM dipendente WHERE matricola='pippo'
tramite il campo fittizio avresti così anche un'indicazione in merito a quale tabella fa riferimento il tuo record.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2008, 16:22   #3
shimo-ne
Junior Member
 
Iscritto dal: Jun 2008
Messaggi: 3
Potresti provare con le join visto che poi tu da codice fai quello alla fine:

select post.id, inserisce.matr_dipendente, dipendente.nome
from post inner join (
inserisce inner join dipendente
on matr_dipendente = matricola )
on id = id_post
order by id desc limit 1;


Quote:
Originariamente inviato da Redvex Guarda i messaggi
Sto facendo un programma in java/jsf/jsp utilizzando mysql come dbms; ora nel get di una variabile eseguo queste 3 query:
Codice PHP:
public String getNome_matr() {
        
sql ="SELECT MAX(id) FROM post";
        
ResultSet rs sqlCommandBean.executeQuery(sql);
        try{
            
rs.next();
            
this.id rs.getInt("MAX(id)");
        }catch (
Exception e){}
        
sql="SELECT matr_dipendente FROM inserisce WHERE id_post='"+this.id+"'";
        
ResultSet rs1 sqlCommandBean.executeQuery(sql);
        try{
            
rs1.next();
          
matr_post rs1.getInt("matr_dipendente");  
        }catch (
Exception e){}
        
sql ="SELECT nome FROM dipendente WHERE matricola='"+matr_post+"'";
        
ResultSet rs2 sqlCommandBean.executeQuery(sql);
        try{
            
rs2.next();
            
nome_matrrs2.getString("nome");
        }catch(
Exception e){}
        return 
nome_matr;
    } 
Come posso concentrare queste 3 query per avere solo 1 resultset?
Avendo delle buone prestazioni magari
shimo-ne è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2008, 16:44   #4
shinya
Senior Member
 
L'Avatar di shinya
 
Iscritto dal: Jul 2005
Città: Bologna
Messaggi: 1130
Io farei una roba cosi (sempre che abbia capito cosa vuoi ottenere):

Codice:
select i.matr_dipendente, d.nome
  from dipendente d join inserisce i on d.matricola = i.matr_dipendente
where i.id_post = (select max(id) from post)
edit: Chiudi quei ResultSet e non scrivere orrori come quel "catch(Exception e){}"!!

Ultima modifica di shinya : 18-06-2008 alle 16:47.
shinya è offline   Rispondi citando il messaggio o parte di esso
Old 18-06-2008, 16:46   #5
Redvex
Senior Member
 
L'Avatar di Redvex
 
Iscritto dal: Apr 2002
Città: Nosgoth
Messaggi: 16899
Quote:
Originariamente inviato da shinya Guarda i messaggi
Io farei una roba cosi (sempre che abbia capito cosa vuoi ottenere):

Codice:
select i.matr_dipendente, d.nome
  from dipendente d join inserisce i on d.matricola = i.matr_dipendente
where i.matr_dipendente = (select max(id)
                                        from post)
Grazie a tutti risolto
__________________
Redvex è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
iPhone 18 Pro: il componente che garanti...
DeepL alza il livello: con Voice-to-Voic...
Apple sta utilizzando sempre più ...
Il MacBook Neo vende tanto? Microsoft le...
AST SpaceMobile BlueBird 7: Blue Origin ...
È il momento migliore per comprar...
Svendita MacBook Pro: c'è il mode...
Oggi questa TV TCL QLED da 43 pollici co...
Il caricatore multiplo da 200W che va be...
Top 7 Amazon, il meglio del meglio di qu...
Spento lo strumento LECP della sonda spa...
Voyager Technologies ha siglato un accor...
GoPro annuncia la linea MISSION 1 con tr...
Alcune varianti dei futuri Samsung Galax...
Il ridimensionamento di OnePlus in Europ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 03:39.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v