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 23-05-2009, 17:33   #1
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
[MySql] Perchè mi da errore quando tento questo insert

Ciao,
ho una tabella fatta così:

Codice:
+-----------------+--------------+------+-----+---------+----------------+
| Field           | Type         | Null | Key | Default | Extra          |
+-----------------+--------------+------+-----+---------+----------------+
| Id_Oggetto      | int(11)      | NO   | PRI | NULL    | auto_increment |
| Titolo          | varchar(60)  | NO   |     | NULL    |                |
| Descrizione     | text         | YES  |     | NULL    |                |
| Costo_Base      | decimal(6,2) | YES  |     | NULL    |                |
| Scadenza        | datetime     | YES  |     | NULL    |                |
| Compralo_Subito | decimal(6,2) | YES  |     | NULL    |                |
| Id_Venditore    | varchar(20)  | NO   |     | NULL    |                |
| Id_Categoria    | varchar(30)  | NO   |     | NULL    |                |
+-----------------+--------------+------+-----+---------+----------------+
Quando tento questo insert però mi da il seguente errore:

Codice:
insert into INSERZIONE values
(NULL, 'Gibson Les Paul', 'Chitarra elettrica Gibson Les Paul del 1977', 300.00, NULL, '2008-02-27', 'usato', 'Salvo', 17),
(NULL, 'Fender Stratocaster', 'Chitarra elettrica Fender Stratocaster del 1973', 300.00, 650.00, '2008-03-04', 'usato', 'Salvo', 17),
(NULL, 'Fear Of The Dark', 'Storico Album degli Iron Maiden blabla', 3.00, NULL, '2008-03-04', 'usato', 'Salvo', 15),
(NULL, 'Cofanetto Metallica', 'Tutta la discografia dei Metallica in un elegante cofanetto', 5.00, 35.00, '2008-03-04', 'nuovo', 'Lalla', 15),
(NULL, 'Cavalletto Manfrotto', 'Ottimo cavalletto Manfrotto', 10.50, 150.00, '2008-03-09', 'nuovo', 'Fotografo84', 10),
(NULL, 'Canon Eos 350D', 'Reflex Digitale', 10.00, NULL, '2008-03-12', 'usato', 'Artista77', 11),
(NULL, 'Radeon 9800 Series', 'Scheda grafica etcetc', 5.00, 75.50, '2008-03-12', 'nuovo', 'IGOR', 4),
(NULL, 'Il Signore degli Anelli', 'Storica trilogia di Tolkien etcetc', 2.00, 25.00, '2008-03-12', 'nuovo', 'IGOR', 4),
(NULL, 'Pacchetto Dylan Dog', 'Raccolta di fumetti dal numero 50 al numero 75 tutti prima edizione', 4.00, 80.00, '2008-03-12', 'nuovo', 'Plutone', 4),
(NULL, 'Photosho CS3 no problem', 'Manuale di Photoshop CS3 etcetc', 2.00, NULL, '2008-03-15', 'usato', 'Ryo', 4),
(NULL, 'Kodak CX3', 'Macchina digitale compatta etcetc', 2.00, NULL, '2008-03-15', 'usato', 'Ryo', 8),
(NULL, 'Vinile Black Sabbath', 'Storico vinile edito nel 1968', 5.00, NULL, '2008-03-17', 'usato', 'Marilu', 15),
(NULL, 'Painkiller: Vinile Judas Priest', 'Storico vinile dei Judas Priest edito nel 1991', 5.00, NULL, '2008-03-18', 'usato', 'FreeMan', 15),
(NULL, 'Fuji FinePix S5700 ', 'Ottima macchina fotografica digitale di tipo bridge balbla', 10.00, 440, '2008-03-19', 'nuovo', 'Fotografo84', 8),
(NULL, 'Kommodor 64', 'Storico computer anni 80, etcetc', 2.00, 35.00, '2008-03-15', 'usato', 'Ryo', 4),
(NULL, 'Asus - X53ke portatile', 'Ottimi computer poratile che integra tutta la potenza del processore AMD Turion 64 etcetc', 50.00, 630.00, '2008-03-19', 'nuovo', 'ComputerMagix', 4),
(NULL, 'Hp Pc portatile pavilion dv6650el', 'Notebook con schermo WXGA da 15,4", risoluzione 1280 x 80 etcetc', 70.00, 80.00, '2008-03-19', 'nuovo', 'ComputerMagix', 4),
(NULL, 'Acer Pc portatile aspire 5920 ', 'Notebook con processore intel core 2 duo', 50.00, 760.00, '2008-03-20', 'nuovo', 'ComputerMagix', 4),
(NULL, 'Olympus E-510', 'Reflex digitale di ultima generazione con sensore stabilizzato', 10.00, 630.00, '2008-03-21', 'nuovo', 'Fotografo84', 7),
(NULL, 'Sigma EF-500 DG ST TTL per Pentax', 'Flash per reflex Pentax prodotto da sigma etcetc', 7.00, NULL, '2008-03-21 17:30:00', 'nuovo', 'Fotografo84', 10);
ERROR 1136 (21S01): Column count doesn't match value count at row 1

Come mai come risolvere?

Ah dimendicavo che la tabella contiene già molti altri record al suo interno

Grazie
Andrea
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 23-05-2009, 18:17   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
la tabella ha 8 colonne, mentre la insert (almeno la prima) ne ha 9
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 23-05-2009, 18:36   #3
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
la tabella ha 8 colonne, mentre la insert (almeno la prima) ne ha 9


Che deficiente che sono...ed ora mi sorge un altro bel problema...nella tabella manca una colonna che dice se l'oggetto a cui si riferisce l'inserzione è nuovo o usato.

La mia tabella Inserzione è piena di dati (tipo 130000 record) che ho inserito si con un programma ma comunque faticosamente perchè il programma fa inserire i record 100 a 100 e ho passato le mezzore a cliccare col mouse....tra l'altro poi la tabella inserzione è collegata con incoli di integrità referenziale ad altre tabelle e sarebbe un casino rifare tutto.

E' possibile fare questa cosa?

Modificare la tabella ed aggiungergli un campo Stato_Oggetto (che può essere o booleano (1: nuovo, 0 usato) o varchar ("nuovo", "usato")) ad ogni record già inserito e possibilmente fare in modo che questo campo assuma casualmente uno dei due valori possibili in fase di modifica della tabella...

E' possibile o si tratta di fantascienza?

Grazie
Andrea
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 23-05-2009, 18:47   #4
qwerty86
Senior Member
 
L'Avatar di qwerty86
 
Iscritto dal: Jun 2007
Messaggi: 1232
Non so dirtelo con certezza ma penso di possa fare. Prova

Ps. se proprio ti da problemi puoi sempre crearti una nuova tabella con i campi che hai più quello che ti serve e poi la riempi con una select dalla tabella che hai ora.
__________________
Cpu: Amd 64 X2 5200+ - Mobo:M2N32SLI DELUXE - Ram: Corsair xms2 800 mhz kit 4gb - SK Video: Gaiward GTS250 - Ali : Enermax Liberty 500 Wat - Mast DVD: 2 Nec AD-5170A - Case : Thermaltake Armor+ - Dissipatore: Thermaltake V1 Notebook: Sony Vaio VGN-Fe21M-Pda: Htc Diamond |Il mio sito|Flickr| Stanco del solito forum? Vieni a parlare di fotografia su Fotoni
qwerty86 è offline   Rispondi citando il messaggio o parte di esso
Old 23-05-2009, 18:58   #5
ndakota
Senior Member
 
L'Avatar di ndakota
 
Iscritto dal: Oct 2006
Città: milano
Messaggi: 1439
se fai un update senza condizione modifichi tutti i campi di una tabella..
ndakota è offline   Rispondi citando il messaggio o parte di esso
Old 23-05-2009, 19:08   #6
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
Quote:
Originariamente inviato da ndakota Guarda i messaggi
se fai un update senza condizione modifichi tutti i campi di una tabella..
che intendi?
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 23-05-2009, 20:22   #7
ndakota
Senior Member
 
L'Avatar di ndakota
 
Iscritto dal: Oct 2006
Città: milano
Messaggi: 1439
se fai

Codice:
UPDATE nome_tabella SET nome_campo = valore
dovresti trovarti con tutti i campi nome_campo di tutte le righe della tabella nome_tabella con il valore valore.

Ultima modifica di ndakota : 23-05-2009 alle 20:36.
ndakota è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2009, 12:20   #8
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
Quote:
Originariamente inviato da ndakota Guarda i messaggi
se fai

Codice:
UPDATE nome_tabella SET nome_campo = valore
dovresti trovarti con tutti i campi nome_campo di tutte le righe della tabella nome_tabella con il valore valore.
eh si questo lo sò ma se valore lo volessi casuale? c'è modo?

Grazie
Andrea
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2009, 12:51   #9
ndakota
Senior Member
 
L'Avatar di ndakota
 
Iscritto dal: Oct 2006
Città: milano
Messaggi: 1439
Quote:
Originariamente inviato da D4rkAng3l Guarda i messaggi
eh si questo lo sò ma se valore lo volessi casuale? c'è modo?

Grazie
Andrea
con sql non penso ma con qualche riga di php dovresti riuscirci..
ndakota è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2009, 15:22   #10
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Codice:
UPDATE inserzione
SET nuovocampo =
  CASE WHEN MOD(LEN(Titolo),2)=1 THEN 1 ELSE 0 END
Cosi' se il titolo ha lunghezza dispari avrai un elemento nuovo, altrimenti usato.
Abbastanza casuale direi
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2009, 15:55   #11
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Codice:
UPDATE inserzione
SET nuovocampo =
  CASE WHEN MOD(LEN(Titolo),2)=1 THEN 1 ELSE 0 END
Cosi' se il titolo ha lunghezza dispari avrai un elemento nuovo, altrimenti usato.
Abbastanza casuale direi
I titolo hanno tutti la stessa lunghezza mi pare perchè sono stati generati con un programma usando una maschera...però potrei usare tale tecnica per qualche altro campo che dovrebbe avere lunghezza variabile...mo provo
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2009, 16:13   #12
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Codice:
UPDATE inserzione
SET nuovocampo =
  CASE WHEN MOD(LEN(Titolo),2)=1 THEN 1 ELSE 0 END
Cosi' se il titolo ha lunghezza dispari avrai un elemento nuovo, altrimenti usato.
Abbastanza casuale direi
mmm ho provato a fare così ma mi dà questo messaggio di errore:

Codice:
mysql> UPDATE inserzione
    -> SET Stato_Oggetto enum('nuovo', 'usato') =
    -> CASE WHEN MOD(LEN(Descrizione),2)= 1 THEN 'nuovo' ELSE 'usato' END;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version
 for the right syntax to use near 'enum('nuovo', 'usato')
CASE WHEN MOD(LEN(Descrizione),2)=1 THEN 'nuovo' ELSE 'us' at line 2
mysql>
Cosa sbaglio? Please è importante

Grazie
Andrea

Ultima modifica di D4rkAng3l : 24-05-2009 alle 17:04.
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2009, 17:36   #13
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
Risolto creando un campo con ALTER TABLE e poi
UPDATE inserzione SET Stato_Oggetto = CASE WHEN(RAND() > 0.5) THEN 'nuovo' ELSE 'usato' END;

D4rkAng3l è 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...
Toy Story 5 arriva al cinema: è l...
Intel cambia rotta su Linux? Nuove assun...
Samsung aggiorna Bixby con One UI 8.5: p...
L'Etiopia vieta le auto a combustione: a...
Pirateria audiovisiva: la Guardia di Fin...
Ubisoft conferma due nuovi Far Cry in sv...
Chi vincerà il Festival di Sanrem...
G42 e Cerebras portano in India un super...
Offerte aggiornate del weekend Amazon: 7...
4 MacBook Air in offerta e scende a 939€...
Chrome cambia il tuo modo di lavorare: o...
Minimo storico iPhone 17 su Amazon: 909€...
USA, incriminati tre ingegneri della Sil...
Xbox: Phil Spencer lascia dopo 38 anni, ...
Cuffie e sostanze chimiche: uno studio e...
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: 17:47.


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