Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Recensione Borderlands 4, tra divertimento e problemi tecnici
Recensione Borderlands 4, tra divertimento e problemi tecnici
Gearbox Software rilancia la saga con Borderlands 4, ora disponibile su PS5, Xbox Series X|S e PC. Tra le novità spiccano nuove abilità di movimento, un pianeta inedito da esplorare e una campagna che lascia al giocatore piena libertà di approccio
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
NXTPAPER 60 Ultra è il primo smartphone con tecnologia NXTPAPER 4.0 per il display, un ampio IPS da 7,2 pollici. Con finitura anti-riflesso, processore MediaTek Dimensity 7400, fotocamera periscopica e modalità Max Ink per il detox digitale, NXTPAPER 60 Ultra punta a essere il riferimento tra gli smartphone pensati per il benessere degli occhi.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-10-2014, 15:16   #1
asghan
Senior Member
 
L'Avatar di asghan
 
Iscritto dal: May 2001
Messaggi: 438
[SQLite] è possibile creare un trigger che...

Ciao

Vorrei creare un trigger che riordini parzialmente i valori della colonna "n"
(solo se necessario incrementandoli di 1)
per evitare duplicati nella colonna "n"
in caso di aggiornamento o nuovo inserimento

ipotizzando una tabella con due colonne come questa
k = integer primary key
n = integer


k n
--------
1 1
2 2
3 3
4 4
5 5
6 6
7 7
9 9

inviando questa questa query

UPDATE tabella SET n=5 WHERE k=4

poi in trigger dovrebbe modificarla cosi

k n
--------
1 1
2 2
3 3
4 5 <---------update
5 6 <---------trigger n+1
6 7 <---------trigger n+1
7 8 <---------trigger n+1
9 9


Sperando di essere stato chiaro, grazie per gli eventuali consigli
asghan è offline   Rispondi citando il messaggio o parte di esso
Old 30-10-2014, 12:01   #2
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Vedi un po' come va... http://sqlfiddle.com/#!7/f7204/1
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 31-10-2014, 12:45   #3
asghan
Senior Member
 
L'Avatar di asghan
 
Iscritto dal: May 2001
Messaggi: 438
Ciao

Cosa rappresenta la "t" presente nel trigger?
Codice:
SELECT 1 FROM tabella t ...

--------------------


ho riscontrato questo inconveniente...
http://sqlfiddle.com/#!7/f7204/8
Codice PHP:
SELECT FROM tabella;
UPDATE tabella SET n 5 WHERE k 4;
SELECT FROM tabella;
UPDATE tabella SET n 5 WHERE k 7;
SELECT FROM tabella order by n;

k      n
1      1
2      2
3      3
4      5           
<--------- questo dovrebbe diventare n+1=6
7      5           
<   update
5      7
6      8
9     10 

e questo …


http://sqlfiddle.com/#!7/f7204/18
Codice PHP:
UPDATE tabella SET n 5 WHERE k 4;
UPDATE tabella SET n 5 WHERE k 7;
UPDATE tabella SET n 8 WHERE k 1;
SELECT FROM tabella order by n;
UPDATE tabella SET n 6 WHERE k 4;
SELECT FROM tabella order by n;


k    n
2    2
3    3
4    5
7    5
5    7
1    8
6    9
9    10



k    n
2    2
3    3
7    5
4    6        
update
5    7
1    9        
dovrebbe restare 8 perche sei non esisteva
6    10      
dovrebbe restare 9
9    11      
dovrebbe restare 10 

grazie
bye bye

Ultima modifica di asghan : 31-10-2014 alle 12:51.
asghan è offline   Rispondi citando il messaggio o parte di esso
Old 31-10-2014, 14:02   #4
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Quando si fanno delle query nidificate che coinvolgono una stessa tabella può essere necessario fare riferimento ai record provenienti dall'una o dall'altra query, per questo bisogna assegnare alla tabella un alias univoco.
In quel caso ho deciso di chiamare la tabella t, ma poteva andar bene un qualunque altro nome.

Ci ragiono un po' e ti faccio sapere.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 31-10-2014, 15:20   #5
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Fosse MySQL sarebbe stato facile, SQLite è molto carente sulle procedure, forse si potrebbe arrangiare qualcosa con dei trigger ricorsivi, ma andrebbe bene solo per tabelle molto molto piccole a causa del limite di ricorsione, e comunque non ho modo di provarlo (sembra che SQL fiddle non consenta l'attivazione dei trigger ricorsivi). Penso che dovrai implementare l'operazione nella tua applicazione oppure passare ad un db più potente.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 06-11-2014, 16:00   #6
asghan
Senior Member
 
L'Avatar di asghan
 
Iscritto dal: May 2001
Messaggi: 438
grazie

puntroppo non posso cambiare db

proverò a trovare una soluzione riducendo al minimo le query

ciao
asghan è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
The Social Reckoning: il seguito di The ...
iPhone 16 si trova ora su Amazon a soli ...
Amazon fa a pezzi i prezzi dei monitor g...
Componenti hardware e periferiche PC a p...
Pianeta in crisi: 7 su 9 limiti vitali g...
Galaxy S25 FE con taglio di prezzo di 10...
4 robot aspirapolvere e 3 scope elettric...
Nuovissimi Xiaomi 15T e 15T Pro con tagl...
Le agenzie federali americane potranno u...
Smartphone pieghevoli sempre più ...
LG svela le Easy TV, una nuova gamma di ...
L'equipaggio della missione Shenzhou-20 ...
Possibili detriti spaziali del razzo cin...
Amazon distrugge i prezzi: TV OLED LG, i...
Trump studia dazi fino al 100% per sping...
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: 22:24.


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