|
|
|
|
Strumenti |
21-05-2018, 10:54 | #1 |
Member
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); ?> 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 ','. ) ) |
22-05-2018, 10:50 | #2 | |
Moderatore
Iscritto dal: Nov 2006
Messaggi: 20825
|
Quote:
__________________
"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 |
|
23-05-2018, 10:39 | #3 |
Member
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:
|
24-05-2018, 14:48 | #4 |
Member
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 |
25-05-2018, 12:25 | #5 |
Member
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 |
26-05-2018, 11:43 | #6 |
Member
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. |
04-06-2018, 10:19 | #7 | |
Member
Iscritto dal: Jan 2013
Messaggi: 92
|
Quote:
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! |
|
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 05:11.