Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-10-2014, 16:16   #1
asghan
Senior Member
 
L'Avatar di asghan
 
Iscritto dal: May 2001
Messaggi: 439
[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, 13: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, 13:45   #3
asghan
Senior Member
 
L'Avatar di asghan
 
Iscritto dal: May 2001
Messaggi: 439
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 13:51.
asghan è offline   Rispondi citando il messaggio o parte di esso
Old 31-10-2014, 15: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, 16: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, 17:00   #6
asghan
Senior Member
 
L'Avatar di asghan
 
Iscritto dal: May 2001
Messaggi: 439
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


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Samsung annuncia l'arrivo in Italia dei ...
Offerta lancio Pixel 10a: come ottenere ...
Google presenta Pixel 10a: poche le novi...
Caos F1 2026: 14 monoposto senza omologa...
Tesla festeggia il primo Cybercab prodot...
Desktop piccolo e potente? NZXT H2 Flow ...
Logan Paul vende la sua carta Pokemon &q...
Polestar spinge sull'acceleratore: arriv...
Nuovo record mondiale nel fotovoltaico: ...
L'ultimo baluardo cade: fine supporto pe...
'Il mondo non ha mai visto nulla di simi...
La Commissione europea mette sotto indag...
Arriva il primo computer quantistico ad ...
'Se lavori al PC sei a rischio': la prev...
Windows 11 introduce il supporto nativo ...
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: 16:16.


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