Torna indietro   Hardware Upgrade Forum > Software > Programmazione

iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Intel Xeon 6+: è tempo di Clearwater Forest
Intel Xeon 6+: è tempo di Clearwater Forest
Intel ha annunciato la prossima generazione di processori Xeon dotati di E-Core, quelli per la massima efficienza energetica e densità di elaborazione. Grazie al processo produttivo Intel 18A, i core passano a un massimo di 288 per ogni socket, con aumento della potenza di calcolo e dell'efficienza complessiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-07-2003, 13:42   #1
L4OA
Senior Member
 
L'Avatar di L4OA
 
Iscritto dal: Jun 2000
Città: Ostia beach [Roma]
Messaggi: 1292
Concatenate in sqlserver2000

Saluti a tutti
sapete come si realizza la concatenate in sqlserver2000??
mi spiego:
io ho sempre lavorato con Oracle e spesso ho dovuto usare
la funzione || per dei confronti particolari
il formato è
select * from tabella where campo1||campo2 = 'XXXXXXXXXXX'
dove le x sono una stringa lunga come la somma delle lunghezze
di campo1 e campo2
in sql server ho provato con:
select * from tabella where campo1 + campo2 = 'XXXXXXXXXXX'
ma funziona solo fino a quando la stringa contiene un certo valore
tipo '00012345678' oltre quel valore mi risponde:
Server: Msg 8115, Level 16, State 8, Line 1
Arithmetic overflow error converting numeric to data type numeric.

che cavolo vuol dire??
grazie in anticipo
__________________
Sometimes it snows in April
Sometimes I feel so bad, so bad
Sometimes I wish life was never ending
And all good things, they say, never last
L4OA è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2003, 01:35   #2
monkey72
Senior Member
 
L'Avatar di monkey72
 
Iscritto dal: Dec 2001
Messaggi: 1385
forse è un problema di precisione più grande di campo1 + campo2 rispetto a 'XXXX...' ... boh... questi concetti di conversione, precisione, casting sono un pò ostici
__________________
lui è il mio amore: "tesò domani ti regalo un guinzaglio lungo 100 km"
monkey72 è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2003, 13:13   #3
cisky
Member
 
L'Avatar di cisky
 
Iscritto dal: Aug 2001
Città: Gerenzano
Messaggi: 129
La concatenazione è corretta con l'operatore '+'

Si verifica un errore di conversione ... la maggior parte delle volte è perchè SQL Server opera una conversione automatica del datatype per eseguire il confronto che non è supportata.

Per ovviare a questo problema devi utilizzare l'apposita funzione CAST che opera la conversione della tipologia del dato.

Ad esempio se hai una tabella 'tblA' con un campo 'CampoA' di tipo SmallInt

Se provi ad eseguire questa Query:
SELECT * FROM tblA WHERE tblA.QT + tblA.QT = '1'

Si verifica questo errore:
[Arithmetic overflow error converting expression to data type Smallint.]

Devi cambiare la tua SQL in questo modo:
SELECT * FROM tblA WHERE CAST(tblA.QT as float) + CAST(tblA.QT as float) ='1'

... ovviamente devi cambiare il datatype in base alle tue esigenze.

Guarda l'Help sulla funzione CAST per vedere le conversioni supportate!

Ciao
__________________
E' quasi tutto relativo!
cisky è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2003, 13:49   #4
monkey72
Senior Member
 
L'Avatar di monkey72
 
Iscritto dal: Dec 2001
Messaggi: 1385
ma allora ci avevo preso!! tnk cisky interessava saperlo anche a me
__________________
lui è il mio amore: "tesò domani ti regalo un guinzaglio lungo 100 km"
monkey72 è offline   Rispondi citando il messaggio o parte di esso
Old 24-07-2003, 14:11   #5
L4OA
Senior Member
 
L'Avatar di L4OA
 
Iscritto dal: Jun 2000
Città: Ostia beach [Roma]
Messaggi: 1292
ho provato con as numeric
e non mi da + errore
però il risultato non va bene...
non mi da nessun record
e poi i campi sono già numeric da 6 e 4
il primo contiene 41013 e l'altro una sequenza da 1 a 100
se io gli metto
cast(campo1 AS NUMERIC) + CAST(campo2 AS NUMERIC) > '0410130020'
non ottengo niente....
qualche idea in proposito??
saluti e grazie
__________________
Sometimes it snows in April
Sometimes I feel so bad, so bad
Sometimes I wish life was never ending
And all good things, they say, never last
L4OA è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2003, 02:22   #6
disumano
Senior Member
 
L'Avatar di disumano
 
Iscritto dal: Jun 2002
Città: NAPOLI!
Messaggi: 1310
forse sparo una corbelleria...

se usi l'operatore + con due numeri, siamo sicuri che otterrai una stringa composta dai due numeri affiancati e non la loro somma?
forse dovresti fare il casting degli argomenti da numeri a stringhe...
e cioé
SELECT * FROM tabella1 WHERE CAST(campo1 as text) + CAST(campo2 as text) ='XXXXXXXXXXX'
disumano è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2003, 02:33   #7
disumano
Senior Member
 
L'Avatar di disumano
 
Iscritto dal: Jun 2002
Città: NAPOLI!
Messaggi: 1310
ho provato a fare una query in access e il modo esatto è questo:

SELECT * FROM tabella1 WHERE cstr(a)+cstr(b)='xxxxxx';

convertendo a e b (campi di tipo numerico) in stringhe.

spero di essere stato d'aiuto.
disumano è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2003, 11:01   #8
L4OA
Senior Member
 
L'Avatar di L4OA
 
Iscritto dal: Jun 2000
Città: Ostia beach [Roma]
Messaggi: 1292
ora sono a casa in malattia
proverò lunedì
ma mi sembra corretto
saluti
__________________
Sometimes it snows in April
Sometimes I feel so bad, so bad
Sometimes I wish life was never ending
And all good things, they say, never last
L4OA è offline   Rispondi citando il messaggio o parte di esso
Old 25-07-2003, 13:03   #9
cisky
Member
 
L'Avatar di cisky
 
Iscritto dal: Aug 2001
Città: Gerenzano
Messaggi: 129
Confermo che funziona!

Perciò la tua SQl sarà:

SELECT * FROM TabellaA WHERE CAST(A as nvarchar)+CAST(B as nvarchar)='XXXXXX'

Ciao!
__________________
E' quasi tutto relativo!
cisky è offline   Rispondi citando il messaggio o parte di esso
Old 30-07-2003, 14:20   #10
L4OA
Senior Member
 
L'Avatar di L4OA
 
Iscritto dal: Jun 2000
Città: Ostia beach [Roma]
Messaggi: 1292
non va...
i campi uniti perdono gli 0 davanti
e quindi se il primo è 0 e il secondo 4 mi diventano 04
e non 0000000004.....
con as text mi dice che nun se pò fa
con char e nvarchar perdo gli zeri e il confronto
mi da risultati sballati...
__________________
Sometimes it snows in April
Sometimes I feel so bad, so bad
Sometimes I wish life was never ending
And all good things, they say, never last
L4OA è offline   Rispondi citando il messaggio o parte di esso
Old 30-07-2003, 15:00   #11
dr.stein
Registered User
 
Iscritto dal: Dec 2001
Messaggi: 890
prova questo:
Codice PHP:
SELECT Format(CAST(as nvarchar)+CAST(as nvarchar);"000000"FROM tabella
dove A e B sono i campi

Ultima modifica di dr.stein : 30-07-2003 alle 15:03.
dr.stein è offline   Rispondi citando il messaggio o parte di esso
Old 30-07-2003, 15:16   #12
L4OA
Senior Member
 
L'Avatar di L4OA
 
Iscritto dal: Jun 2000
Città: Ostia beach [Roma]
Messaggi: 1292
la select:
select * from tb_rivendite
where FORMAT(cast(trvn_precodice_istat as nvarchar) +
cast(trvn_cd_rivendita as nvarchar);"0000000000")
> '0000000004'

la risposta
Server: Msg 170, Level 15, State 1, Line 3
Line 3: Incorrect syntax near ';'.

.....
__________________
Sometimes it snows in April
Sometimes I feel so bad, so bad
Sometimes I wish life was never ending
And all good things, they say, never last
L4OA è offline   Rispondi citando il messaggio o parte di esso
Old 30-07-2003, 15:41   #13
L4OA
Senior Member
 
L'Avatar di L4OA
 
Iscritto dal: Jun 2000
Città: Ostia beach [Roma]
Messaggi: 1292
ma che sql è?? mysql??
la format non c'è tra le funzioni di sqlserver2000
__________________
Sometimes it snows in April
Sometimes I feel so bad, so bad
Sometimes I wish life was never ending
And all good things, they say, never last
L4OA è offline   Rispondi citando il messaggio o parte di esso
Old 30-07-2003, 15:48   #14
dr.stein
Registered User
 
Iscritto dal: Dec 2001
Messaggi: 890
Access!!!

per questo pensavo che in SQL2000 andasse bene!!
dr.stein è offline   Rispondi citando il messaggio o parte di esso
Old 30-07-2003, 15:55   #15
L4OA
Senior Member
 
L'Avatar di L4OA
 
Iscritto dal: Jun 2000
Città: Ostia beach [Roma]
Messaggi: 1292
prodotti MS compatibili tra loro???

utopista

intanto mi sto scaricando il book online della MS x sqlserver
i soliti 36mb.... compressi in .cab
__________________
Sometimes it snows in April
Sometimes I feel so bad, so bad
Sometimes I wish life was never ending
And all good things, they say, never last
L4OA è offline   Rispondi citando il messaggio o parte di esso
Old 30-07-2003, 16:54   #16
L4OA
Senior Member
 
L'Avatar di L4OA
 
Iscritto dal: Jun 2000
Città: Ostia beach [Roma]
Messaggi: 1292
risolto... ovviamente senza l'aiuto del book...

i pratica se uso la cast as varchar mi tira fuori delle stringhe
prive degli zeri a sx degli importi
quindi mi costruisco la stringa di confronto
eliminando gli zeri a sx

ovvero se avevo 041013 e 0020
al confronto gli passo 04101320
che è la stessa stringa che mi restituisce se la cast la uso nella select
e non nella where

spero di essere stato chiaro

ps
ovviamente accedo a sqlserver2000 con il cobol
__________________
Sometimes it snows in April
Sometimes I feel so bad, so bad
Sometimes I wish life was never ending
And all good things, they say, never last
L4OA è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Recensione Google Pixel Watch 4: basta sollevarlo e si ha Gemini sempre al polso Recensione Google Pixel Watch 4: basta sollevarl...
2 Smart TV 4K in super offerta su Amazon...
AMD e Intel celebrano un anno di collabo...
NVIDIA consegna il suo mini supercompute...
La concorrenza cinese si fa sentire: il ...
4 accessori auto da non perdere su Amazo...
Era finito, eccolo ancora: torna il supe...
Game Pass: tutte le novità di nov...
Xiaomi 15T e 15T Pro con fotocamere by L...
3 portatili un super sconto: 355€ con 16...
Il nuovo iPhone pieghevole costerà...
MediaTek Dimensity 9500 sfida lo Snapdra...
Nuovo storico lancio per il razzo spazia...
Elgato Embrace: una sedia ergonomica pro...
Brad Pitt torna in pista: F1 – Il Film a...
Hitachi Vantara annuncia la sua AI Facto...
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: 08:07.


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