|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
|
[Ottimizzazione] Quale delle due soluzioni è migliore?
come da domanda, secondo voi quale soluzione è migliore?
Codice:
String query="select ID_RISTAMPA from RISTAMPE where "+ "CONTO_CORRENTE="+inputForm.getContoCorrente()+" and "+ "DATA_ALLIBRAMENTO_FROM="+Util.formatView2DBDate(inputForm.getDataAllibramentoFrom())+" and "+ "DATA_ALLIBRAMENTO_TO="+Util.formatView2DBDate(inputForm.getDataAllibramentoTo()); Codice:
String conto=inputForm.getContoCorrente(); String dataA=Util.formatView2DBDate(inputForm.getDataAllibramentoFrom()); String dataTo=Util.formatView2DBDate(inputForm.getDataAllibramentoTo()); String query="select ID_RISTAMPA from RISTAMPE where "+ "CONTO_CORRENTE="+conto+" and "+ "DATA_ALLIBRAMENTO_FROM="+dataA+" and "+ "DATA_ALLIBRAMENTO_TO="+dataTo;
__________________
My gaming placement |
|
|
|
|
|
#2 | ||
|
Senior Member
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
|
Migliore in che senso?
Spezzone 1: Codice:
String query="select ID_RISTAMPA from RISTAMPE where " + "CONTO_CORRENTE=" + inputForm.getContoCorrente() + " and " + "DATA_ALLIBRAMENTO_FROM=" + Util.formatView2DBDate(inputForm.getDataAllibramentoFrom()) + " and " + "DATA_ALLIBRAMENTO_TO=" + Util.formatView2DBDate(inputForm.getDataAllibramentoTo()); Quote:
Codice:
String conto=inputForm.getContoCorrente(); String dataA=Util.formatView2DBDate(inputForm.getDataAllibramentoFrom()); String dataTo=Util.formatView2DBDate(inputForm.getDataAllibramentoTo()); String query="select ID_RISTAMPA from RISTAMPE where " + "CONTO_CORRENTE=" + conto + " and " + "DATA_ALLIBRAMENTO_FROM=" + dataA + " and " + "DATA_ALLIBRAMENTO_TO=" + dataTo; Quote:
Totale spezzone 2: 4+8 = 12 string creation Ottimizzazione: usa uno StringBuilder. @EDIT: Sempre ammesso che si parlasse di "ottimizzazione" circa l'uso delle stringhe e basta. Altrimenti potresti usare i PreparedStatement invece di costruire la query concatenando stringhe, ci sono diversi vantaggi nel farlo (evitare sql injection, precompilare lo statement).
__________________
As long as you are basically literate in programming, you should be able to express any logical relationship you understand. If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it. (Chris Crawford) Ultima modifica di banryu79 : 26-10-2012 alle 13:53. |
||
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Oct 2005
Messaggi: 3306
|
La prima risposta che mi viene in mente è nessuna delle 2.
Le query composte come concatenamento di stringhe sono il male assoluto. Poi passando alle performance della soluzione forse è il caso di usare StringBuilder (a occhio mi pare che il codice sia Java). |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Jul 2011
Messaggi: 381
|
Ma per "migliore" cosa intendi? Efficienza in tempo o in spazio?
Ricollegandomi a quello che ha detto banryu79, dal mio punto di vista, riferendomi alla complessità computazionale, i due esempi sono uguali. Dato che generalmente la creazione di stringhe ha complessità unitaria, quindi alla fine il tuo codice apparterrà alla classe di complessità della più grande ( "O grande" ) delle funzioni: inputForm.getContoCorrente() Util.formatView2DBDate(inputForm.getDataAllibramentoFrom()) Util.formatView2DBDate(inputForm.getDataAllibramentoTo()) Quindi se per esempio la getDataAllibramentoFrom ha complessità n^2 e le altre due hanno complessità n entrambi i codici alla fine avranno complessità O(n^2).
__________________
Concluso positivamente con: Kamzata, Ducati82, Arus, TheLastRemnant, ghost driver, alexbull1, DanieleRC5, XatiX Ultima modifica di starfred : 28-10-2012 alle 10:47. |
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
|
grazie a tutti e scusate se non ho risposto prima, ma ho avuto un pò da fare.
Sono passato ad uno stringbuilder, e mi interessava proprio la "computazione", ovvero se è peggio concatenare tante volte le stringhe oppure se è peggio creare tante variabili con spezzoni. la disquisizione sulla complessità però mi ha fatto ragionare che praticamente, dato che stiamo parlando di pochi dati, è praticamente ininfluente. credo che a livello spaziale lo stringbuilder ottimizzi il tutto, mentre a livello temporale credo siano equivalenti
__________________
My gaming placement |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 22:43.



















