Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Zenfone 11 Ultra: il flagship ASUS ritorna a essere un 'padellone'
Recensione Zenfone 11 Ultra: il flagship ASUS ritorna a essere un 'padellone'
Zenfone 11 Ultra ha tantissime qualità interessanti, fra cui potenza da vendere, un display di primissimo livello, un comparto audio potente e prestazioni di connettività fra le migliori della categoria. Manca però dell'esclusività del predecessore, che in un settore composto da "padelloni" si distingueva per le sue dimensioni compatte. Abbiamo provato il nuovo flagship ASUS, e in questa recensione vi raccontiamo com'è andata.
Appian: non solo low code. La missione è l’ottimizzazione dei processi con l'IA
Appian: non solo low code. La missione è l’ottimizzazione dei processi con l'IA
Abbiamo partecipato ad Appian World 2024, evento dedicato a partner e clienti che si è svolto recentemente nei pressi di Washington DC, vicino alla sede storica dell’azienda. Nel festeggiare il 25mo anniversario, Appian ha annunciato diverse novità in ambito intelligenza artificiale
Lenovo ThinkVision 3D 27, la steroscopia senza occhialini
Lenovo ThinkVision 3D 27, la steroscopia senza occhialini
Primo contatto con il monitor Lenovo ThinkVision 3D 27 che grazie a particolari accorgimenti tecnici riesce a ricreare l'illusione della spazialità tridimensionale senza che sia necessario utilizzare occhialini
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 21-05-2018, 10:54   #1
neorob
Member
 
L'Avatar di neorob
 
Iscritto dal: Jan 2006
Città: Brescia
Messaggi: 93
[PHP/MSSQL] - Sintassi query errata

Ciao a tutti,
ho un database MSSQL dal quale devo estrapolare dei dati. Questo è il codice:

Codice:
<?php			
						$sql = 'SELECT CONCAT(RIGHT(dbo."UNITA LOCALI".PRECOD, 6), ".", dbo."UNITA LOCALI".COD) as TEST FROM dbo."UNITA LOCALI"';
							

						$result = sqlsrv_query( $conn, $sql);
						if( $result === false ) {die( print_r( sqlsrv_errors(), true));}
						while($obj = sqlsrv_fetch_object( $result))
							{
							echo "<tr><td>";
							echo $obj->TEST."</td></tr>";
							}
						sqlsrv_close($conn);
					?>
la sintassi SQL funziona benissimo con Heidi, e il programma funziona bene con un generico SELECT * FROM dbo."UNITA LOCALI" (con gli opportuni aggiustamenti sugli echo).
Con questa richiesta SQL, mi viene restituito l'errore

[code]Array ( [0] => Array ( [0] => 42000 [SQLSTATE] => 42000 [1] => 102
Codice:
 => 102 [2] => [Microsoft][ODBC Driver 13 for SQL Server][SQL Server]Sintassi non corretta in prossimit� di ','. [message] => [Microsoft][ODBC Driver 13 for SQL Server][SQL Server]Sintassi non corretta in prossimit� di ','. ) )
Il vero problema credo siano gli apici e le virgolette... Ho provato di tutto ma non riesco a farlo funzionare... Avete suggerimenti?
neorob è offline   Rispondi citando il messaggio o parte di esso
Old 22-05-2018, 10:50   #2
!fazz
Moderatore
 
L'Avatar di !fazz
 
Iscritto dal: Nov 2006
Messaggi: 20825
Quote:
Originariamente inviato da neorob Guarda i messaggi
Ciao a tutti,
ho un database MSSQL dal quale devo estrapolare dei dati. Questo è il codice:

Codice:
<?php			
						$sql = 'SELECT CONCAT(RIGHT(dbo."UNITA LOCALI".PRECOD, 6), ".", dbo."UNITA LOCALI".COD) as TEST FROM dbo."UNITA LOCALI"';
							

						$result = sqlsrv_query( $conn, $sql);
						if( $result === false ) {die( print_r( sqlsrv_errors(), true));}
						while($obj = sqlsrv_fetch_object( $result))
							{
							echo "<tr><td>";
							echo $obj->TEST."</td></tr>";
							}
						sqlsrv_close($conn);
					?>
la sintassi SQL funziona benissimo con Heidi, e il programma funziona bene con un generico SELECT * FROM dbo."UNITA LOCALI" (con gli opportuni aggiustamenti sugli echo).
Con questa richiesta SQL, mi viene restituito l'errore

[code]Array ( [0] => Array ( [0] => 42000 [SQLSTATE] => 42000 [1] => 102
Codice:
 => 102 [2] => [Microsoft][ODBC Driver 13 for SQL Server][SQL Server]Sintassi non corretta in prossimit� di ','. [message] => [Microsoft][ODBC Driver 13 for SQL Server][SQL Server]Sintassi non corretta in prossimit� di ','. ) )
Il vero problema credo siano gli apici e le virgolette... Ho provato di tutto ma non riesco a farlo funzionare... Avete suggerimenti?
fai una prova brutale, prova ad copiare da heidi le virgolette e copiarle nel codice php, uso raramente sql server e mai php ma con mysql e .net ho lo stesso problema (il carattere che mysql vuole per l'apice è diverso dal carattere della tastiera italiana )
__________________
"WS" (p280,cx750m,4790k+212evo,z97pro,4x8GB ddr3 1600c11,GTX760-DC2OC,MZ-7TE500, WD20EFRX)
Desktop (three hundred,650gq,3800x+nh-u14s ,x570 arous elite,2x16GB ddr4 3200c16, rx5600xt pulse P5 1TB)+NB: Lenovo p53 i7-9750H,64GB DDR4,2x1TB SSD, T1000
!fazz è offline   Rispondi citando il messaggio o parte di esso
Old 23-05-2018, 10:39   #3
iezzetto
Member
 
L'Avatar di iezzetto
 
Iscritto dal: Jan 2013
Messaggi: 92
Che versione stai utulizzando di SQL SERVER?

Una cosa che devi togliere sono le doppie virgolette.
Non sono riconosciute nella query.

lo schema (dbo) se è unico puoi evitare di inserirlo in quanto di default punta su quello.

La query dovresti provare a farla in questo modo

Codice PHP:
$sql 'SELECT CONCAT(RIGHT([UNITA LOCALI].PRECOD, 6), \'.\', [UNITA LOCALI].COD) as TEST FROM [UNITA LOCALI]'
iezzetto è offline   Rispondi citando il messaggio o parte di esso
Old 24-05-2018, 14:48   #4
neorob
Member
 
L'Avatar di neorob
 
Iscritto dal: Jan 2006
Città: Brescia
Messaggi: 93
Dopo esperimenti vari e testa rotta contro il muro per la disperazione, ho trovato la soluzione!

PREMESSA: SQL Server 11.0.6020 su MS Server2012 R2 + PHP 7.2

SOLUZIONE:
la query che avevo indicato funziona bene con Heidi. Con PHP ho risolto usando la barra prima degli apici nel comando CONCAT ( \'.\' ).
Invece, non so come mai, le " vanno bene. Però mi piace anche la soluzione delle parentesi [quadre]. rRnde più leggibile il codice.
Ora finalmente funziona!
Grazie
neorob è offline   Rispondi citando il messaggio o parte di esso
Old 25-05-2018, 12:25   #5
iezzetto
Member
 
L'Avatar di iezzetto
 
Iscritto dal: Jan 2013
Messaggi: 92
Si le parentesi evitano prarecchi problemi di lettura.

Anche se io generalmente non amo chiamare gli oggetti con gli spazi. Di solito concateno con gli underscore!

Scusami se ti chiedo.
Ma lavori sotto ambiente linux o windows?

Che driver hai usato per la connessione a SQLSERVER con php? PDO?

Ciao
iezzetto è offline   Rispondi citando il messaggio o parte di esso
Old 26-05-2018, 11:43   #6
neorob
Member
 
L'Avatar di neorob
 
Iscritto dal: Jan 2006
Città: Brescia
Messaggi: 93
Purtroppo il database no l'ho creato io, ma fa parte di un programma per la gestione dei rifiuti. Oltre che a costare uno sproposito, il programma è lento come la morte (dico solo che quando si apre una "maschera" impiega circa 2 secondi dal click.... tempi inaccettabili).
Da qui l'idea di usare php per visualizzare i dati di cui ho bisogno, senza troppi giri e perdite di tempo.

Lavoro in ambiente windows, e si, ho usato i drivers PDO per la connessione al database.
neorob è offline   Rispondi citando il messaggio o parte di esso
Old 04-06-2018, 10:19   #7
iezzetto
Member
 
L'Avatar di iezzetto
 
Iscritto dal: Jan 2013
Messaggi: 92
Quote:
Originariamente inviato da neorob Guarda i messaggi
Purtroppo il database no l'ho creato io, ma fa parte di un programma per la gestione dei rifiuti. Oltre che a costare uno sproposito, il programma è lento come la morte (dico solo che quando si apre una "maschera" impiega circa 2 secondi dal click.... tempi inaccettabili).
Da qui l'idea di usare php per visualizzare i dati di cui ho bisogno, senza troppi giri e perdite di tempo.

Lavoro in ambiente windows, e si, ho usato i drivers PDO per la connessione al database.
La maggior parte della lentezza è data dalle query fatte con i piedi (non so se le hai fatte tu! ).

MSSQL ficca tutto nella ram, e più ne ha, più se ne prende (se non è tutto ottimizzato)

Lavora molto sull'ottimizzazione delle query e utilizza l'analizzatore delle query di SQL.
Ti dà tutte le tempistiche ed è utile per ottimizzare!
iezzetto è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Zenfone 11 Ultra: il flagship ASUS ritorna a essere un 'padellone' Recensione Zenfone 11 Ultra: il flagship ASUS ri...
Appian: non solo low code. La missione è l’ottimizzazione dei processi con l'IA Appian: non solo low code. La missione è ...
Lenovo ThinkVision 3D 27, la steroscopia senza occhialini Lenovo ThinkVision 3D 27, la steroscopia senza o...
La Formula E può correre su un tracciato vero? Reportage da Misano con Jaguar TCS Racing La Formula E può correre su un tracciato ...
Lenovo LEGION e LOQ: due notebook diversi, stessa anima gaming Lenovo LEGION e LOQ: due notebook diversi, stess...
Sta per succedere! La prima gara a guida...
Parthenope: un nuovo RPG investigativo t...
Urbanista Malibu: ecco come va la cassa ...
Gas Station Simulator è costato 1...
AOC Graphic Pro U3, tre nuovi monitor pe...
Wacom Movink: per la prima volta il disp...
HPE Aruba presenta i nuovi access point ...
Lamborghini presenta Urus SE, prima vers...
Scuderia Ferrari e HP insieme: ufficiale...
Snapdragon X Plus, un nuovo SoC per i no...
L'iPad 10,9'' 64 GB è sceso a meno di 40...
Steam: basta ai furbetti dell'accesso an...
Motorola Edge 40 Neo con fotocamera da 5...
Arriva Kasperksy Next, la nuova gamma di...
Fallout, un successo senza fine: 1 milio...
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: 02:42.


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