Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet
Il nuovo Deebot X12 OmniCyclone abbina un sistema di raccolta dello sporco senza sacchetto, un rullo di lavaggio esteso e la tecnologia FocusJet per intervenire più efficacemente sulle macchie più persistenti. Un robot completo e preciso che aiuta a tenere puliti i pavimenti di casa con il minimo sforzo
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2: la pulizia di casa con un mocio a nastro
Narwal Flow 2 implementa un mocio a nastro che esegue una pulizia dettagliata del pavimento di casa, in abbinamento ad un potente motore di aspirazione della polvere: un prodotto ideale per gestire in autonomia e con grande efficacia le necessità di pulizia dei pavimenti di casa
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
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


Ecovacs Deebot X12 OmniCyclone: lava grazie a FocusJet Ecovacs Deebot X12 OmniCyclone: lava grazie a Fo...
Narwal Flow 2: la pulizia di casa con un mocio a nastro Narwal Flow 2: la pulizia di casa con un mocio a...
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...
Huawei punta sul canale europeo: per il ...
Ubuntu 26.04: le GPU guadagnano il 17% i...
La Commissione UE registra l'iniziativa ...
SSD troppo cari? La soluzione alla crisi...
Anteprima mondiale Hyundai IONIQ 3: segm...
Fintool sbarca su Microsoft 365: arrivan...
Hanno chiesto 1 dollaro per salvare un M...
Arriva AgentExchange, il marketplace di ...
Blizzard fa chiudere Turtle WoW: perché ...
Claude Desktop e la modifica silenziosa ...
Blue Origin ha mostrato gli interni del ...
Linux alla pari di Windows in gioco: con...
Il rientro del secondo stadio del razzo ...
Il controller ufficiale Microsoft per Xb...
DJI Power 1000 Mini: la power station da...
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: 01:28.


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