|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Member
Iscritto dal: Dec 2004
Città: Treviso e Udine
Messaggi: 258
|
[Java] SQL, connessione e ResultSet
Una domanda piuttosto semplice per chi se ne intende: ho un applicazione server-oriented (servlet) che apre un'unica connessione ad un database SQL Server 2000. Essa viene aperta al momento dell'init().
Diversi utenti accedono alla servlet in contemporanea, sfruttando diverse sessioni ma la stessa connessione. Ciascun utente, a sua volta, lavorando crea diversi ResultSet, i quali restano aperti finchè l'utente ne fa uso. La mia domanda è: una singola connessione quanti accessi contemporaneai (intesi in questo caso come ResultSet aperti) può supportare? |
![]() |
![]() |
![]() |
#2 |
Senior Member
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
|
Ciao,
giusto per rammentare: immagino che tu sappia che da uno Statement non e' detto che possa avere piu' di un ResultSet. Per ogni client, quindi, dovrai fare attenzione a creare uno statement e poi distruggerlo. Non ne farei quindi un problema di connessioni quanto di Statement. Se questo numero e' insufficiente per quello che devi fare, esistono delle tecniche per creare dei pool di connessioni, ma questo lo affronterei solo nel caso si presenti il problema. Per sapere il numero di statement che puoi aprire da una connessione, devi: - ottenere i metadati dalla connessione (getMetaData(), ti restituisce un oggetto di tipo DatabaseMetaData); - chiamare il metodo getMaxStatements(); High Flying Sottovento
__________________
In God we trust; all others bring data |
![]() |
![]() |
![]() |
#3 |
Member
Iscritto dal: Dec 2004
Città: Treviso e Udine
Messaggi: 258
|
Capito e per sapere quanti statement sono aperti in un dato momento? Sempre coi metadati?
|
![]() |
![]() |
![]() |
#4 | |
Senior Member
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
|
Quote:
Penso che non sia possibile ottenere questa informazione, nemmeno con i metadati. (Spero per te che qualcuno piu' esperto mi possa smentire). E' probabile che la possibilita' di ottenere questa info sia dipendente dall'implementazione specifica di un driver jdbc, per cui risulti dipendente dall'accoppiata db+jdbc in uso. Prova a consultare la documentazione del tuo database. Ovviamente, per prova puoi fare un programma che continua ad aprire Statement fino al fallimento dell'operazione, dopo di che puoi guardare il codice di errore ritornato dall'eccezione. Almeno sai quando hai raggiunto il valore massimo, e potresti dimensionare la tua applicazione in modo da non raggiungerlo. Piccolo suggerimento: e' altresi' probabile che alcuni valori, tipici di un database, possano essere ottenuti mediante delle query su speciali tabelle. Prova a guardare e se trovi qualcosa, pubblica i risultati che sono interessanti High Flying Sottovento
__________________
In God we trust; all others bring data |
|
![]() |
![]() |
![]() |
#5 |
Member
Iscritto dal: Dec 2004
Città: Treviso e Udine
Messaggi: 258
|
Tra le tabelle di sistema non ho trovato niente di ciò, cmq ho trovato un'utility di interrogazione tramite il Server Enterprise che mi dice quante interazioni/statement sono contemporaneamente aperte... (anche se lui parla di connessioni attive sono sicuro che si tratta di statement).
Tuttavia, dubito sia attendibile a meno che qualcuno o qualcosa tra il JDBC il Tomcat e l'SQL Server non abbia un sistema automatico di sospensione degli statement: il numero sembra aumentare e diminuire senza una logica precisa, nonostante io non ricompili il codice e non gli faccia chiudere gli statement aperti... ![]() |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 05:41.