Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro)
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro)
Google Pixel 10 Pro XL è il top di gamma della serie Pixel, presentando un ampio display Super Actua da 6.8 pollici insieme alle novità della serie, fra cui la ricarica wireless magnetica Pixelsnap e le nuove funzionalità AI avanzate. Il comparto fotografico include un sistema a tripla fotocamera con zoom Pro Res fino a 100x, mentre il processore Tensor G5 con 16GB di RAM garantisce prestazioni percepite molto elevate su Android.
Lenovo IdeaPad Slim 3: un notebook Snapdragon X economico
Lenovo IdeaPad Slim 3: un notebook Snapdragon X economico
Forte della piattaforma Qualcomm Snapdragon X, il notebook Lenovo IdeaPad Slim 3 riesce a coniugare caratteristiche tecniche interessanti ad uno chassis robusto, con autonomia di funzionamento a batteria che va ben oltre la tipica giornata di lavoro. Un notebook dal costo accessibile pensato per l'utilizzo domestico o in ufficio, soprattutto con applicazioni native per architettura ARM
Recensione OnePlus Watch 3 43mm: lo smartwatch che mancava per i polsi più piccoli
Recensione OnePlus Watch 3 43mm: lo smartwatch che mancava per i polsi più piccoli
OnePlus risponde alle esigenze di chi cerca un dispositivo indossabile dalle dimensioni contenute con OnePlus Watch 3 43mm. La versione ridotta del flagship mantiene gran parte delle caratteristiche del modello maggiore, offrendo un'esperienza completa in un formato compatto. Il suo limite più grande è abbastanza ovvio: l'autonomia non è il punto di forza di questo modello, ma si raggiungono comodamente le due giornate piene con un uso normale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-11-2009, 15:40   #1
bobotti
Member
 
Iscritto dal: Jul 2008
Messaggi: 38
[JAVA][JDBC][SQL Server 2005] Salvare Image object in un campo BLOB

SALVE!!

Premetto che in SQL Server i campi BLOB (almeno così ho capito) possono essere del tipo varbinary(N), detto ciò vorrei inserire in una tabella utenti, nel campo varbinary(MAX) chiamato "avatar" una piccola immagine racchiusa in un'istanza di Image.

Ho fatto i seguenti tentativi:
Image avatar;
Connection dbConnection;
byte b[];
Codice:
b=convertImage(avatar);
ByteArrayInputStream ba=new ByteArrayInputStream(b);
				
System.out.println(b.length+" "+ba.available());
//update user avatar on db
st=dbConnection.prepareStatement(update);
//st.setBlob(1, ba); TENTATIVO 1
//st.setBinaryStream(1, ba); TENTATIVO 2
//st.setBytes(1, b); TENTATIVO 3
st.set
st.executeUpdate();
st.close();
La stringa update:
Codice:
query="UPDATE UTENTI"+
"SET avatar = ? "+
 "WHERE id_utente='"+user.code+
"';";
La println mi dà due numeri uguali (85663) perciò il dato esiste.

Tutti e tre i tentativi (1,2,3), ovviamente provati singolarmente, lanciano sempre una SQLException:
Incorrect syntax near 'avatar'. S001 Codice 102.

Le ho provate tutte (tranne una che però non conosco)!

Suggerimenti?? Grazie

Ultima modifica di bobotti : 26-11-2009 alle 15:43.
bobotti è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2009, 15:48   #2
bottomap
Member
 
Iscritto dal: Feb 2005
Città: Prato
Messaggi: 149
Ciao,

Per il recupero e l'impostazione di BLOB e CLOB da jdbc per un SQLServer dai un'occhiata qui:
http://msdn.microsoft.com/en-us/libr...SQL.90%29.aspx

In particolare lo spezzone:
Codice:
Statement stmt = con.createStatement();
PreparedStatement pstmt = con.prepareStatement("INSERT INTO test1 VALUES( ?, ? )");
FileReader in = new FileReader(new File("CLOBFile20mb.txt");
long len = fileIn.length();
int id = 1;
pstmt.setInt(1,id);
pstmt.setCharacterStream(2, in, (int)len);
pstmt.executeUpdate();
in.close();
lavora direttamente con uno Stream da file, ma non dovrebbe risultare complicato trasformare il tutto per farlo lavorare con una serie di byte in memoria, anzi il tuo ByteArrayInputStream dovrebbe già andare bene.
Anche per il recupero dei dati da un BLOB/CLOB c'è un esempio appropriato.

Edit: Sbagliato completamente il discorso... mi son fatto sviare dal BLOB/CLOB senza vedere il problema reale.
Se la stringa che usi è quella che hai postat è semplicemente un problema di query... ricontrolla attentamente quello che hai scritto (messo su una linea vedi meglio dove sta l'errore).

Ciaociao
__________________
Venite a visitarci qui:http://www.bottomap.com
Bottomap is a proud Masterdrive.it moderator

Ultima modifica di bottomap : 26-11-2009 alle 15:56.
bottomap è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2009, 16:02   #3
bobotti
Member
 
Iscritto dal: Jul 2008
Messaggi: 38
Quote:
Originariamente inviato da bottomap Guarda i messaggi
Ciao,

Per il recupero e l'impostazione di BLOB e CLOB da jdbc per un SQLServer dai un'occhiata qui:
http://msdn.microsoft.com/en-us/libr...SQL.90%29.aspx

lavora direttamente con uno Stream da file, ma non dovrebbe risultare complicato trasformare il tutto per farlo lavorare con una serie di byte in memoria, anzi il tuo ByteArrayInputStream dovrebbe già andare bene.
Anche per il recupero dei dati da un BLOB/CLOB c'è un esempio appropriato.

Edit: Sbagliato completamente il discorso... mi son fatto sviare dal BLOB/CLOB senza vedere il problema reale.
Se la stringa che usi è quella che hai postat è semplicemente un problema di query... ricontrolla attentamente quello che hai scritto (messo su una linea vedi meglio dove sta l'errore).

Ciaociao

Ho letto, ho incapsulato il ByteArrayInputStream in un InputStramReader per renderlo compatibile con setCharacterStream ma l'errore viene fuori uguale...

Ora provo con un file per vedere se dà lo stesso errore.
bobotti è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2009, 16:03   #4
bottomap
Member
 
Iscritto dal: Feb 2005
Città: Prato
Messaggi: 149
Ciao,

Avevo editato il post precedente... rileggi bene l'edit in coda... l'errore è nella query, non nel modo con cui accedi ai dati o con cui imposti i dati.

Ciaociao
__________________
Venite a visitarci qui:http://www.bottomap.com
Bottomap is a proud Masterdrive.it moderator
bottomap è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2009, 16:04   #5
bobotti
Member
 
Iscritto dal: Jul 2008
Messaggi: 38
Quote:
Originariamente inviato da bottomap Guarda i messaggi
Ciao,

Per il recupero e l'impostazione di BLOB e CLOB da jdbc per un SQLServer dai un'occhiata qui:
http://msdn.microsoft.com/en-us/libr...SQL.90%29.aspx

In particolare lo spezzone:
Codice:
Statement stmt = con.createStatement();
PreparedStatement pstmt = con.prepareStatement("INSERT INTO test1 VALUES( ?, ? )");
FileReader in = new FileReader(new File("CLOBFile20mb.txt");
long len = fileIn.length();
int id = 1;
pstmt.setInt(1,id);
pstmt.setCharacterStream(2, in, (int)len);
pstmt.executeUpdate();
in.close();
lavora direttamente con uno Stream da file, ma non dovrebbe risultare complicato trasformare il tutto per farlo lavorare con una serie di byte in memoria, anzi il tuo ByteArrayInputStream dovrebbe già andare bene.
Anche per il recupero dei dati da un BLOB/CLOB c'è un esempio appropriato.

Edit: Sbagliato completamente il discorso... mi son fatto sviare dal BLOB/CLOB senza vedere il problema reale.
Se la stringa che usi è quella che hai postat è semplicemente un problema di query... ricontrolla attentamente quello che hai scritto (messo su una linea vedi meglio dove sta l'errore).

Ciaociao
OMMIODDIOOOOOOO
Grazie!!
Odio questi errori...
bobotti è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2009, 16:05   #6
bobotti
Member
 
Iscritto dal: Jul 2008
Messaggi: 38
Ormai saranno 4 ore che sto così... Preferivo non saperlo!!
E non è la prima/decima volta questa settimana!

mitico funziona

Ultima modifica di bobotti : 26-11-2009 alle 16:07.
bobotti è offline   Rispondi citando il messaggio o parte di esso
Old 26-11-2009, 16:07   #7
bottomap
Member
 
Iscritto dal: Feb 2005
Città: Prato
Messaggi: 149
Hehe, dai non abbatterti... son cose che capitano...

Piuttosto per il futuro ricordati che quando ottieni un errore da oracle, 8 volte su 10 è un problema nella sintassi usata all'interno della query. In particolare un errore di tipo "Incorrect syntax near..." è generalmente da imputarsi ad una query malformata.

Se fai errori con preparedstatement o con metodi del resulset in genere è quest'ultimo che lancia un'eccezione piuttosto che il driver jdbc.
(Le due volte su dieci in cui il problema non è nella query, in genere è nella connessione tra l'applicativo ed il DBMS).

Ciaociao
__________________
Venite a visitarci qui:http://www.bottomap.com
Bottomap is a proud Masterdrive.it moderator
bottomap è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro) Recensione Google Pixel 10 Pro XL: uno zoom 100x...
Lenovo IdeaPad Slim 3: un notebook Snapdragon X economico Lenovo IdeaPad Slim 3: un notebook Snapdragon X ...
Recensione OnePlus Watch 3 43mm: lo smartwatch che mancava per i polsi più piccoli Recensione OnePlus Watch 3 43mm: lo smartwatch c...
BOOX Note Air4 C è uno spettacolo: il tablet E Ink con Android per lettura e scrittura BOOX Note Air4 C è uno spettacolo: il tab...
Recensione Sony Xperia 1 VII: lo smartphone per gli appassionati di fotografia Recensione Sony Xperia 1 VII: lo smartphone per ...
Grazie a VLT di ESO c'è una nuova...
Tape-out completato per la GPU Rubin e l...
NVIDIA GeForce RTX: le schede video più ...
Google trasforma il suo Traduttore: dive...
Computer portatile HP 15,6'' Full HD con...
Da Netatmo il kit che taglia i consumi: ...
SpaceX: Elon Musk parla delle future Sta...
Microsoft licenzia due dipendenti che ha...
Colpo di scena Formula 1 2026: potenza t...
Microsoft estende Xbox Cloud Gaming agli...
AMD tornerà nella fascia alta? Un...
Windows 10, Microsoft rilascia uno degli...
La spettacolare Nebulosa Farfalla &egrav...
Ring Intercom a 49,99€ e super sconti su...
In Cina è entrata in funzione la ...
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: 13:04.


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