Torna indietro   Hardware Upgrade Forum > Software > Programmazione

MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
Dopo anni di attesa e una lunga fase di sviluppo, Noctua entra nel mercato dei dissipatori a liquido AIO con la nuova serie NL-LC1. Forte dell'esperienza maturata nel raffreddamento ad aria, l'azienda austriaca promette di portare la propria filosofia fatta di qualità costruttiva, attenzione ai dettagli e silenziosità anche in questo segmento. Abbiamo provato il nuovo sistema per scoprire se riesce a distinguersi in un mercato ormai molto competitivo.
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Arrivato sul mercato italiano a fine marzo, la serie Boox Go 10.3 (Gen II) offre Android 15, penna da 4096 livelli e retroilluminazione opzionale (nel modello da noi provato, Lumi, presente). La serie si compone di due tablet ePaper che fanno da e-reader, blocco note digitale e persino browser, tutto a un prezzo che fa dimenticare i prodotti di brand più blasonati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-10-2007, 13:14   #1
supersasch2006
Junior Member
 
L'Avatar di supersasch2006
 
Iscritto dal: Oct 2007
Messaggi: 8
[Java] Domandina suoi form e sul ResultSet di JDBC

Allora premetto che non è da molto ke programmo in Java e sto imparando. Ho scaricato NetBeans come tool di sviluppo...ora io ho la classe Main che fa partire il mio programma ...
da li apro il mio primo form
Codice:
jfLogin mm = new jfLogin();
        mm.setVisible(true);
ok e tutto fila liscia ... ora questo form ha il controllo di accedere al db controllado il nome utente e la password.
Se il controllo va a buon fine la finestra si dovrebbe chiudere ed aprire il menù principale ... ora però il menù principale me lo apre senza problemi ... ma non mi chiude il form del login
in VB avevo la classe me che indicava il form aperto e lanciavo
me.close()
ma i Java come si fa ??

Altra cosa nessuno di voi sa come si contano le righe di un ResultSet ??
tipo
Codice:
String queryName = “SELECT * FROM Studenti WHERE nome = ‘Marco’”;
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery(queryName);
come faccio a vedere quante righe ha rs ??


grazie mille Sascha
supersasch2006 è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2007, 13:20   #2
yorkeiser
Senior Member
 
L'Avatar di yorkeiser
 
Iscritto dal: Jul 2006
Città: Tristram
Messaggi: 517
Quote:
Originariamente inviato da supersasch2006
Altra cosa nessuno di voi sa come si contano le righe di un ResultSet ??
tipo
Codice:
String queryName = “SELECT * FROM Studenti WHERE nome = ‘Marco’”;
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery(queryName);
come faccio a vedere quante righe ha rs ??


grazie mille Sascha
Non ho mai incontrato una funzione specifica per contare le righe di un resultset, non so se possa esistere sinceramente. Comunque puoi aggirare il problema in 2 modi:

O fai una query di count (select COUNT(*) FROM ....) e fai un rs.getInt(),

oppure quando scrolli il resultset incrementi un contatore
Codice:
int numero_righe=0;
while rs.next() numero_righe ++ ;
__________________
Il sole è giallo
yorkeiser è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2007, 14:00   #3
supersasch2006
Junior Member
 
L'Avatar di supersasch2006
 
Iscritto dal: Oct 2007
Messaggi: 8
ok grazie mille per la risposta... tante volte mica mi sai aiutare sul discorso dei form ...
supersasch2006 è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2007, 14:11   #4
supersasch2006
Junior Member
 
L'Avatar di supersasch2006
 
Iscritto dal: Oct 2007
Messaggi: 8
leggendo un po' a zonzo per internet ho trovato un interessante soluzione al problema ... posto il codice

Codice:
    public static ResultSet query = null;
    public static int contaRighe() {
        try {
            int risu=0;
            query.last();
            risu = query.getRow();
            query.first();
            
            return risu;
            
        } catch (SQLException se) {
            if (DEBUG) {
                System.out.println("Impossibile completare la query: ");
                se.printStackTrace();
            }
       } 
       return 0;
    }
naturalmente il ResultSet deve essere Scrollable ResultSet


idea presa da qui http://www.oracle.com/technology/sam...untResult.html
__________________
!! Welcome to the Real World !!
supersasch2006 è offline   Rispondi citando il messaggio o parte di esso
Old 19-10-2007, 14:17   #5
yorkeiser
Senior Member
 
L'Avatar di yorkeiser
 
Iscritto dal: Jul 2006
Città: Tristram
Messaggi: 517
Certo: non ho mai incontrato un problema simile per cui ignoravo che esistesse anche un rs.last(), ma direi che questa è la soluzione migliore quando non si ha il bisogno di scorrere tutto il recordset.
__________________
Il sole è giallo
yorkeiser è offline   Rispondi citando il messaggio o parte di esso
Old 21-10-2007, 13:44   #6
supersasch2006
Junior Member
 
L'Avatar di supersasch2006
 
Iscritto dal: Oct 2007
Messaggi: 8
Tanto che ci sono posto la classe che mi sono fatto per PostgreSQL, non so se a qualcuno può servire
Codice:
package papinicomp_java.funzioni;
import javax.swing.JOptionPane;
import java.sql.*;

/**
 *
 * @author Sascha
 */
public class jcPostgreSQL {
    
    //variabili che servono per connettersi al DB
    public static String HOST = "10.3.0.1";
    public static String USER = "root";
    public static String PASS = "-";
    public static String DB = "papinicomputer";
    
    public static boolean DEBUG = true;
    
    //variabile che tiene la connessione
    public static Connection myDb = null;
    public static ResultSet query = null;
    
    /** Creates a new instance of jcPostgreSQL */
    public jcPostgreSQL() {
    }
    
    public static boolean connetti() {
        try {
            myDb = DriverManager.getConnection("jdbc:postgresql://10.3.0.1/papinicomputer", USER, PASS);
            if (DEBUG) {
                if (myDb != null) {
                    System.out.println("Connessione con il server " + HOST + " riuscita !!");
                    return true;
                } else {
                    System.out.println("Connessione con il server " + HOST + " NON riuscita !!");
                    return false;
                }
            }
        } catch (SQLException se) {
            if (DEBUG) {
                System.out.println("Impossibile connettersi: ");
                se.printStackTrace();
                return false;
            }
       }   
       return false;
    }
    
    public static void chiudi() {
        try {
            myDb.close();
            System.out.println("Connessione con il DB chiusa ");
            
        } catch (SQLException se) {
            if (DEBUG) {
                System.out.println("Impossibile connettersi: ");
                se.printStackTrace();
            }
       }   
    }
    
    public static void queryDB(String q) {
        try {
            if (DEBUG) {
                System.out.println(q);
            }
            Statement s = myDb.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
            query = s.executeQuery(q);
            
        } catch (SQLException se) {
            if (DEBUG) {
                System.out.println("Impossibile completare la query: ");
                se.printStackTrace();
            }
       }  
    }
    
    public static int contaRighe() {
        try {
            int risu=0;
            query.last();
            risu = query.getRow();
            query.first();
            
            return risu;
            
        } catch (SQLException se) {
            if (DEBUG) {
                System.out.println("Impossibile completare la query: ");
                se.printStackTrace();
            }
       } 
       return 0;
    }
    
    public static int contaRigheColonne() {
        try {
            java.sql.ResultSetMetaData rsmd = query.getMetaData();
            return rsmd.getColumnCount();
            
        } catch (SQLException se) {
            if (DEBUG) {
                System.out.println("Impossibile completare la query: ");
                se.printStackTrace();
            }
       } 
       return 0;
    }
    
}
__________________
!! Welcome to the Real World !!
supersasch2006 è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2007, 16:55   #7
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da supersasch2006 Guarda i messaggi
...
Se il controllo va a buon fine la finestra si dovrebbe chiudere ed aprire il menù principale ... ora però il menù principale me lo apre senza problemi ... ma non mi chiude il form del login
in VB avevo la classe me che indicava il form aperto e lanciavo
me.close()
ma i Java come si fa ??
Della serie: meglio tardi che mai!

me.setVisible(false);
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
ChatGPT lancia Scheduled Tasks: gestione...
Kodak Charmera Millennium Edition: torna...
Il catalogo di XBOX Game Pass sempre pi&...
Il futuro della medicina? Midjourney vuo...
Ricercatori di Harvard codificano 169 by...
AOC E4: monitor ergonomici per PMI con r...
Apple guarda al futuro: il primo chip a ...
L'addio al PC un autogol per PlayStation...
DJI Mini 4K parte da 179€, DJI Neo da 13...
WINDTRE alza ancora i prezzi: sesta rimo...
iPhone 18 potrebbe avere più RAM ...
The Witcher, in arrivo anche un gioco mu...
Un miliardo di utenti non basta: ChatGPT...
Carl Pei di Nothing sfida Apple: 'Vi rub...
Morale a terra in casa Meta: persino i d...
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: 08:36.


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