Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-09-2009, 11:00   #1
VegetaSSJ5
Senior Member
 
L'Avatar di VegetaSSJ5
 
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
[SQL] Chiedo aiuto per una query su SQL Server 2008

Salve a tutti.
Devo implementare una query di ricerca in un'applicazione web i cui dati si trovano su un db SQL Server 2008.

La query in realtà già esiste e funziona bene, però deve essere modificata.
Partiamo da un esempio dal basso. La query è del tipo:
Codice:
SELECT col1, col2, col3
FROM tab1 (join.....)
WHERE condizione
AND (col1 LIKE '%valore%' OR col2 LIKE '%valore%' OR col3 LIKE '%valore%')
Poichè bisogna gestire la paginazione la query diventa:
Codice:
SELECT * FROM (

SELECT col1, col2, col3, ROWNUM() OVER (ORDER BY col1 ASC) AS ROWNUM
FROM tab1 (join...)
WHERE condizione
AND (col1 LIKE '%valore%' OR col2 LIKE '%valore%' OR col3 LIKE '%valore%')

)  AS result WHERE result.ROWNUM BETWEEN 1 AND 15
In questo modo vengono restituiti solo i valori dalla posizione 1 alla 15.

Fin qui tutto bene, la query funziona perfettamente.

Ora però andrebbe modificata in questo modo: nel risultato devono comparire prima i record dove il LIKE è stato trovato nel campo col2, poi i record dove il LIKE è stato trovato negli altri campi. Mi è venuto in mente di fare una union in questo modo:
Codice:
SELECT * FROM (

SELECT col1, col2, col3, ROWNUM() OVER (ORDER BY col1 ASC) AS ROWNUM
FROM tab1 (join...)
WHERE condizione
AND (col2 LIKE '%valore%')

UNION

SELECT col1, col2, col3, ROWNUM() OVER (ORDER BY col1 ASC) AS ROWNUM
FROM tab1 (join...)
WHERE condizione
AND (col1 LIKE '%valore%' OR col3 LIKE '%valore%')

)  AS result WHERE result.ROWNUM BETWEEN 1 AND 15
Sarebbe una buona soluzione in quanto effettivamente vengono restituiti prima tutti i record in cui il like è stato trovato nel campo col2 e poi gli altri, però in questo modo i campi ROWNUM delle 2 query si duplicano creando problemi quindi con la paginazione.

Sapete suggerirmi qualcosa per risolvere il problema?
Grazie!

Ultima modifica di VegetaSSJ5 : 09-09-2009 alle 11:02.
VegetaSSJ5 è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2009, 20:15   #2
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Non ho sql server a portata di mano e lo conosco poco. In mysql farei così, ma suppongo sia la stessa cosa anche col tuo rdbms.

Codice:
select *,if(col2 like "%pippo%",1,0) as ordine
from tabella
where col1 like "%pippo%" or col2 like "%pippo%" or col3 like "%pippo%"
order by ordine desc
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2009, 20:59   #3
VegetaSSJ5
Senior Member
 
L'Avatar di VegetaSSJ5
 
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
Quote:
Originariamente inviato da john_revelator Guarda i messaggi
Non ho sql server a portata di mano e lo conosco poco. In mysql farei così, ma suppongo sia la stessa cosa anche col tuo rdbms.

Codice:
select *,if(col2 like "%pippo%",1,0) as ordine
from tabella
where col1 like "%pippo%" or col2 like "%pippo%" or col3 like "%pippo%"
order by ordine desc
grazie!
ho capito l'idea ma non saprei come riprodurre in sql server questo: if(col2 like "%pippo%",1,0)
VegetaSSJ5 è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2009, 23:07   #4
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Adesso mi è stato possibile testare la cosa.

Codice:
select *,
case
when col2 like '%pippo%' then 1 else 0 end 
as ordine
from tabella
where col1 like '%pippo%' or col2 like '%pippo%' or col3 like '%pippo%'
order by ordine desc
In effetti usando l'if non funzionava. So che in questo forum gli esperti di sql server non mancano. Sicuramente qualcuno ci dirà se è possibile risolvere anche con l'if.

edit. Ho fatto una rapida gugolata e mi pare di capire che non esista proprio il costrutto if ma che sia sempre necessario ricorrere al case.

Ultima modifica di john_revelator : 09-09-2009 alle 23:14.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 10-09-2009, 08:54   #5
EnricoHU
Member
 
Iscritto dal: Feb 2009
Messaggi: 112
in teoria, potresti usare un'istruzione del genere:

SELECT * FROM (

SELECT col1, col2, col3, ROWNUM() OVER (ORDER BY col1 ASC) AS ROWNUM
FROM tab1 (join...)
WHERE condizione
AND (col2 LIKE '%valore%')

UNION

SELECT col1, col2, col3, 10000 + ROWNUM() OVER (ORDER BY col1 ASC) AS ROWNUM
FROM tab1 (join...)
WHERE condizione
AND (col1 LIKE '%valore%' OR col3 LIKE '%valore%')

) AS result WHERE result.ROWNUM BETWEEN 1 AND 15 or result.ROWNUM BETWEEN 10001 AND 10015

in questo modo dovresti ottenere le prime 15 righe della prima e le prime 15 della seconda
EnricoHU è offline   Rispondi citando il messaggio o parte di esso
Old 10-09-2009, 10:26   #6
VegetaSSJ5
Senior Member
 
L'Avatar di VegetaSSJ5
 
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
Quote:
Originariamente inviato da EnricoHU Guarda i messaggi
in teoria, potresti usare un'istruzione del genere:

SELECT * FROM (

SELECT col1, col2, col3, ROWNUM() OVER (ORDER BY col1 ASC) AS ROWNUM
FROM tab1 (join...)
WHERE condizione
AND (col2 LIKE '%valore%')

UNION

SELECT col1, col2, col3, 10000 + ROWNUM() OVER (ORDER BY col1 ASC) AS ROWNUM
FROM tab1 (join...)
WHERE condizione
AND (col1 LIKE '%valore%' OR col3 LIKE '%valore%')

) AS result WHERE result.ROWNUM BETWEEN 1 AND 15 or result.ROWNUM BETWEEN 10001 AND 10015

in questo modo dovresti ottenere le prime 15 righe della prima e le prime 15 della seconda
ci ho provato ma mettendo il 10000 dopo, cioè ... ROWNUM() OVER (...) + 10000 AS ROWNUM...

ma non funziona, cioè la query viene eseguita correttamente ma non viene aggiunto il valore 10000...
VegetaSSJ5 è offline   Rispondi citando il messaggio o parte di esso
Old 10-09-2009, 14:06   #7
EnricoHU
Member
 
Iscritto dal: Feb 2009
Messaggi: 112
strano

purtoppo non ho modo di testare, però ho trovato quest'altro comando che potrebbe fare al caso tuo

SELECT TOP 15 ROW_NUMBER() OVER (ORDER BY Date DESC) AS Row
EnricoHU è offline   Rispondi citando il messaggio o parte di esso
Old 10-09-2009, 16:04   #8
VegetaSSJ5
Senior Member
 
L'Avatar di VegetaSSJ5
 
Iscritto dal: Sep 2002
Città: Celano (AQ) Segno_Zodiacale: Leone Ascendente: Cammello Segni_Particolari: Quello
Messaggi: 9571
Quote:
Originariamente inviato da EnricoHU Guarda i messaggi
strano

purtoppo non ho modo di testare, però ho trovato quest'altro comando che potrebbe fare al caso tuo

SELECT TOP 15 ROW_NUMBER() OVER (ORDER BY Date DESC) AS Row
il fatto è che quel rownumber mi serve per gestire la paginazione, ed è quindi dinamico... quindi in questo esempio prende i valori tra 1 e 15, ma in una ipotetica pagina 5 prende i valori tra 76 e 90.
VegetaSSJ5 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Apple Studio Display finalmente in offer...
OpenAI sfida Google e lancia ChatGPT Tra...
Attenti ai commenti LinkedIn: come ricon...
Xiaomi Redmi Note 15 al prezzo minimo ga...
REDMI Buds 8 Lite in arrivo in Italia: A...
USA: i dettagli del via libera condizion...
I nuovi REDMI Note 15 Series arrivano in...
Mini compressore portatile a prezzo stra...
X limita Grok: stop alle immagini sessua...
Dopo essere diventato indipendente, GOG ...
L'idea del CEO Fiat: abbassare la veloci...
Ricavi record per TSMC nel quarto trimes...
vivo X300 Pro scende di 200€ su Amazon c...
Prezzi alle stelle per gli smartphone: i...
God of War: individuato l'attore che int...
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: 11:24.


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