Onkohan mahdollista käyttää kahta tietokantayhteyttä samaan aikaan?
Jostakin syystä vaikka nimeän yhteydet erinimisiksi, niin en pysty käyttämään niitä yhtäaikaa, vaan ohjelma yrittää hakea samaa taulua myös toisesta tietokannasta.
$yhteysa = mysql_connect();
mysql_select_db(tietokanta1,yhteysa);
$yhteysb = mysql_connect();
mysql_select_db(tietokanta2,yhteysb);
$kysely = SELECT * FROM taulu;
mysql_query($kysely, $yhteysa) or die (mysql_error());
--> virhe on että kysely yrittää hakea tuota tietoa tietokanta 2:sesta vaikka sitä ei ole edes tuossa määritelty.
Mikähän mahtaa olla ongelma ja mitenhän sen voisi ratkaista?
miksi ei onnistu
4
387
Vastaukset
- The Rat
Eikös yhteyttä muodostaessa olisi hyvä määrittää tietokanta, johon yhteys muodostetaan?
http://fi.php.net/manual/en/function.mysql-connect.php
Tuon mukaan otat molemmat connectit samaan kantaa...- tmt_79
mysql_connect() ei ota mitään kantaa mihin tietokantaan se yhdistyy. Sen tehtävänä on ainoastaan luoda kahva sopivan palvelimen porttiin 3306. mysql_select_db sen sijaan valitsee tietokannan, joskin sen nimi tulisi olla lainausmerkeissä.
- kiitoksia vuan
No nii.. tuollahan se olikin vastaus kysymykseen.
For example, you are opening two separate connections to two different databases (but on the same host, and with the same user and password):
$db1 = mysql_connect($dbhost, $dbuser, $dbpass);
$rv = mysql_select_db($dbname1, $db1);
$db2 = mysql_connect($dbhost, $dbuser, $dbpass);
$rv = mysql_select_db($dbname2, $db2);
At this point, both $db1 and $db2 will have selected the database named by $dbname2.
The workaround is to require that the second MySQL connection is new:
$db1 = mysql_connect($dbhost, $dbuser, $dbpass);
$rv = mysql_select_db($dbname1, $db1);
$db2 = mysql_connect($dbhost, $dbuser, $dbpass, TRUE);
$rv = mysql_select_db($dbname2, $db2); - löytyi joka tapauksessa
tmt_79 kirjoitti:
mysql_connect() ei ota mitään kantaa mihin tietokantaan se yhdistyy. Sen tehtävänä on ainoastaan luoda kahva sopivan palvelimen porttiin 3306. mysql_select_db sen sijaan valitsee tietokannan, joskin sen nimi tulisi olla lainausmerkeissä.
Tosiaan vastaajan selitys taisi olla väärä, mutta vastaus löytyi tuolta sivulta.. Se näkyy käyttävän tuota entistä yhteyttä ja näin ollen valitsee myös sen mukaan otetun tietokannan. Pitää antaa true arvo uudelle yhteyden muodostamiselle, jolloin voi valita myös toisen tietokannan.
Taisi olla vain siinä tapauksessa, jos käyttäjänimet ja salasanat ovat samat. En nyt aivan tarkalleen lukenut asiasta tuolta.
Joka tapauksessa nyt toimii.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
- 1686777
Klaukkalan onnettomuus 4.4
Klaukkalassa oli tänään se kolmen nuoren naisen onnettomuus, onko kellään mitään tietoa mitä kävi tai ketä onnettomuudes522101- 562078
Ukraina ja Zelenskyn ylläpitämä sota tuhoaa Euroopan, ei Venäjä
Mutta tätä ei YLE eikä Helsingin Sanomat kerto.3521200- 541192
Kolari Klaukkala
Kaksi teinityttö kuoli. Vastaantulijoille ei käynyt mitenkään. Mikä auto ja malli telineillä oli entä se toinen auto? Se571184Ooo! Kaija Koo saa kesämökille öky-rempan:jättimäinen terde, poreallas... Katso ennen-jälkeen kuvat!
Wow, nyt on Kaija Koon mökkipihalla kyllä iso muutos! Miltä näyttää, haluaisitko omalle mökillesi vaikkapa samanlaisen l141071Olisinpa jo siellä, otatkohan minut vastaan
Olisitpa lähelläni ja antaisit minun maalata sinulle kuvaa siitä kaikesta ikävästä, tuskasta, epävarmuudesta ja mieleni79950Kevyt on olo
Tiedättekö, että olo kevenee kummasti, kun päästää turhista asioista tai ihmisistä irti! Tämä on hyvä näin <384938Toivoisin, että lähentyisit kanssani
Tänään koin, että välillämme oli enemmän. Kummatkin katsoivat pidempään kuin tavallisesti toista silmiin. En tiedä mistä14927