Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-10-2006, 10:59   #1
El GianGio
Junior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 12
Php + ADODB + Linux + MS SQLServer

Salve a tutti, ho installato sulla mia macchina linux (distro Ubuntu) Apache2 + Php5. Ora devo connettermi ad un db MS SQLServer e per farlo ho pensato di usare le librerie ADODB ma la pagina php che ho fatto non sembra funzionare. Qualcuno sa il perchè? Il codice che effettua la connect e la query è il seguente

Codice:
<?php

// libreria da includere per la connessione con il database
include('../adodb/adodb.inc.php');

$ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;

$conn = ADONewConnection('odbc_mssql');
$dsn = "Driver={SQL Server};Server=$server;Database=$db;";
$conn -> Connect($dsn, $username, $password);
if (!$conn) die("Connection failed");

$rsAule = $conn -> Execute($qryAule);

if (!$rsAule) {
	echo $conn -> ErrorMsg();
	die("<br />Unable to execute the query");
}

$rsAule -> MoveFirst();
?>
mentre l'errore che mi ritorna è il seguente

Codice:
Warning: odbc_connect() [function.odbc-connect]: SQL error: [unixODBC][Driver Manager]Data source name not found, and no default driver specified, SQL state IM002 in SQLConnect in /var/www/adodb/drivers/adodb-odbc.inc.php on line 60
[unixODBC][Driver Manager]Data source name not found, and no default driver specified
Unable to execute the query
Da ciò che mi risponde mi sembra di capire che la connessione al db riesce a farla (dopotutto è un warning) ma poi si blocca sulla query. Quello che non riesco a capire è perchè se metto le stesse pagine php su una macchina windows funzionino correttamente.

Vi ringrazio anticipatamente per l'aiuto .

El GianGio
El GianGio è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 19:03   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Mmmmhmhmhhh...come fa a funzionare ADO da Linux ? Dove hai le librerie ?!!?

Leggi qui come si fa a connettersi a MS SQL da Linux: http://it.php.net/manual/it/ref.mssql.php

Ultima modifica di cionci : 16-10-2006 alle 08:40.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2006, 19:16   #3
El GianGio
Junior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 12
Le librerie le importo tramite il comando

Codice:
include('../adodb/adodb.inc.php');
e si trovano nella cartella superiore a quella che contiene le mie pagine php. Inoltre adodb è una libreria opensource realizzata per PHP e Phyton per consentire di astrarsi dal db (http://adodb.sourceforge.net/).
Comunque ora mi leggerò il link che mi hai dato per vedere se riesco a risolvere qualcosa .

Grazie
El GianGio è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2006, 11:38   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Bello dare un nome registrato ad una libreria open
ADODB è l'oggetto di Microsoft per conenttersi ai database...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2006, 11:54   #5
Ducati 998
Senior Member
 
L'Avatar di Ducati 998
 
Iscritto dal: Feb 2003
Messaggi: 321
Guarda non conosco ADODB, però posso dirti che io ho fatto delle chiamate verso MSSQL da Linux.
Basta installare sulla macchina linux FreeTds, ed in fase di compilazione del Php abilitare le chiamate di MSSQL. Alla fine utilizzi le classiche mssql_query() etc...
__________________
Troy Bayliss: l'eroe dei 2 mondi!! W-SBK Champion e vincitore della gara MotoGP di Valencia 2006!
Ducati 998 è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2006, 17:09   #6
El GianGio
Junior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 12
Penso proprio che farò una prova con le classiche mssql_query come dici tu. Inoltre credo che freeTDS sia già correttamente installato sulla mia distro di Ubuntu perchè digitando da shell il comando "isql -v MSSql username passwd" riesco a connettermi al db e quindi fare tutte le query che desidero. Questo però da linea di comando mentre io devo farlo fare alle mie pagine php.
L'unica cosa che non so fare è compilare php abilitando le chiamate di MSSQL (sai com'è vengo dal mondo windows e mi sto avvicinando ora a linux ), sapresti darmi una dritta su come fare?
Inoltre mi stavo chiedendo, non può essere che il problema risieda proprio nella mia errata configurazione di PHP? Magari se lo compilo come dici tu, però abilitando anche qualche altro modulo come unixODBC (ammesso che esista), le mie pagine PHP dovrebbero funzionare, giusto?

El GianGio
El GianGio è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2006, 08:47   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Come è scritto al link sopra, devi compilare con l'opzione --with-mssql. Credo che questo sia un parametro che devi dare al file ./configure che trovi nella distro del sorgente di php...
Quindi:

./configure --with-mssql (=DIR lo devi mettere se non ti funziona)
make
make install
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2006, 11:17   #8
Ducati 998
Senior Member
 
L'Avatar di Ducati 998
 
Iscritto dal: Feb 2003
Messaggi: 321
Quote:
Originariamente inviato da cionci
Come è scritto al link sopra, devi compilare con l'opzione --with-mssql. Credo che questo sia un parametro che devi dare al file ./configure che trovi nella distro del sorgente di php...
Quindi:

./configure --with-mssql (=DIR lo devi mettere se non ti funziona)
make
make install
La DIR dovrebbe puntare alla directory dove hai installato le librerie che ti permettono di interpretare correttamente il resource di ritorno ad una query di MSSQL.
Nella pratica io faccio così:

Prendo FreeTds e lo installo in questa maniera, ovviamente mettendomi all'interno della directory dove ho scompattato i sorgenti:
./configure --prefix=/usr/local/freetds --with-tdsver=8.0
make
make install
Nella configurazione di freetds ho messo tdsver=8.0 perché mi aggancio a MSSQL Server 2000, se hai versioni più vecchie o altre versioni devi verificare sulla documentazione di freetds. Considera che questo parametro può essere cambiato anche dopo la compilazione, basta andare a smanipolare sul file di configurazione di freetds... adesso il nome non mi sovviene ma basta guardare sul sito web.

Poi passo all'installazione e compilazione di Php, che faccio in questa maniera, ovviamente mettendomi all'interno della directory dove ho scompattato i files sorgenti, e considerando di aver installato Apache2 dentro la cartella /usr/local/apache2:
./configure --prefix=/usr/local/Php --with-apxs2=/usr/local/apache2/bin/apxs --with-mssql=/usr/local/freetds
make
make install
In questo modo setti Php per lavorare con mssql. Attento però che se ti servono altre estensioni le devi esplicitare quando esegui il comando ./configure. Per capirci, per abilitare per esempio anche mysql devi metterci --with-mysql e pure --enable-mbstring... insomma sta a te decidere quali estensioni compilare ed abilitare a php.
__________________
Troy Bayliss: l'eroe dei 2 mondi!! W-SBK Champion e vincitore della gara MotoGP di Valencia 2006!
Ducati 998 è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2006, 16:43   #9
El GianGio
Junior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 12
Per chi è interessato e ha riscontrato il mio stesso problema, volevo dire che sono riuscito a trovare la soluzione.
In pratica il problema consisteva nella linea di codice php all'interno della pagina dove indicavo il dsn:
Codice:
$dsn = "Driver={SQL Server};Server=$server;Database=$db;";
In pratica su sistemi windows questo comando funzionava alla perfezione mentre in ambiete linux no (probabilmente perchè non gli ho spiegato dove andarsi a prendere il driver del db nel file system). Infatti il driver manager (che è unixODBC) va a guardare il file odbc.ini per sapere quale dsn prendere in considerazione. Al suo interno ho messo tutte le informazioni necessarie indicando il nome con cui mi riferirò a quel dsn tra parentesi quadre, ad es:
Codice:
[DSNname1]
Driver = /pathTo/libtdsodbc.so (il percorso al file dei driver)
Server = dbserver.exmple.com (oppure l'indirizzo ip del mio server)
Database = dbname (il nome del db da interrogare)
TDS_Version = 8.0 (la versione migliore per MS SQL)
Fatto questo posso semplicemente sostituire nella riga di codice php precedente il nome che ho usato all'interno del file odbc.ini, ottengo così:
Codice:
$dsn = "DSNname1";
Da questo momento in poi le mie pagine php sono in grado di connettersi ed interrogare correttamente il db sfruttando le librerie ADOdb che mi sono importato

Spero che questo post sia di aiuto a qualcun'altro che, come me, è alle prime armi nel mondo linux e proviene dal mondo windows. Grazie a tutti per i consigli.
Ciao!
El GianGio è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
I modelli AI cinesi sono ormai a pochi m...
Netflix diventa la casa globale dei film...
Monitor gaming in forte sconto su Amazon...
500 miliardi di dollari e meno dazi: l'a...
Da Detroit scopriamo le livree di Red Bu...
Microsoft, Meta e Amazon aderiscono al p...
Microsoft integrerà Copilot in Es...
Samsung Internet for Windows: il browser...
Logitech fa sul serio: mouse PRO, tastie...
Spotify aumenta ancora il prezzo del ser...
Bose QuietComfort Ultra (2ª Gen) scendon...
ASUS annuncia l'arrivo in Italia di due ...
Apple prepara l'addio al notch su smartp...
Linux cresce grazie all'addio a Windows ...
Forza un ufficio, smonta le memorie dal ...
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: 10:09.


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