Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro punta a diventare uno dei riferimenti assoluti nel segmento dei camera phone di fascia alta. Con un teleobiettivo Hasselblad da 200 MP, una batteria al silicio-carbonio da 7500 mAh e un display da 6,78 pollici con cornici ultra ridotte, il nuovo flagship non teme confronti con la concorrenza, e non solo nel comparto fotografico mobile. La dotazione tecnica include il processore MediaTek Dimensity 9500, certificazione IP69 e un sistema di ricarica rapida a 80W
DJI Romo, il robot aspirapolvere tutto trasparente
DJI Romo, il robot aspirapolvere tutto trasparente
Anche DJI entra nel panorama delle aziende che propongono una soluzione per la pulizia di casa, facendo leva sulla propria esperienza legata alla mappatura degli ambienti e all'evitamento di ostacoli maturata nel mondo dei droni. Romo è un robot preciso ed efficace, dal design decisamente originale e unico ma che richiede per questo un costo d'acquisto molto elevato
DJI Osmo Nano: la piccola fotocamera alla prova sul campo
DJI Osmo Nano: la piccola fotocamera alla prova sul campo
La nuova fotocamera compatta DJI spicca per l'abbinamento ideale tra le dimensioni ridotte e la qualità d'immagine. Può essere installata in punti di ripresa difficilmente utilizzabili con le tipiche action camera, grazie ad una struttura modulare con modulo ripresa e base con schermo che possono essere scollegati tra di loro. Un prodotto ideale per chi fa riprese sportive, da avere sempre tra le mani
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: 2682
[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: 2682
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: 2682
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: 2682
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: 2682
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: 2682
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: 2682
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


OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh OPPO Find X9 Pro: il camera phone con teleobiett...
DJI Romo, il robot aspirapolvere tutto trasparente DJI Romo, il robot aspirapolvere tutto trasparen...
DJI Osmo Nano: la piccola fotocamera alla prova sul campo DJI Osmo Nano: la piccola fotocamera alla prova ...
FUJIFILM X-T30 III, la nuova mirrorless compatta FUJIFILM X-T30 III, la nuova mirrorless compatta
Oracle AI World 2025: l'IA cambia tutto, a partire dai dati Oracle AI World 2025: l'IA cambia tutto, a parti...
Il Giappone un passo più vicino a...
Gli interferometri LIGO, Virgo e KAGRA h...
Kia PV5: è record di autonomia! I...
L'aeroplano supersonico ''silenzioso'' N...
Nissan: le batterie allo stato solido co...
NVIDIA cambia strategia? La GPU Feynman ...
Signal respinge le accuse dopo il down A...
Uragano Melissa in arrivo: la tempesta d...
8K o 4K? Ecco perché il tuo occhi...
Mercato auto europeo in crescita nei pri...
Addio SSD e RAM, benvenuti funghi: dagli...
TCL Q6C: tecnologia e design per un TV c...
Corsair MP700 PRO XT al debutto: un SSD ...
Apple Watch Ultra 2 in titanio con GPS +...
Nuova protezione per Windows 11: scansio...
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: 20:37.


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