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
426
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
Vain vasemmistolaiset rakennemuutokset pelastavat Suomen
Kansaa on ankeutettu viimeiset 30+ vuotta porvarillisella minäminä-talouspolitiikalla, jossa tavalliselta kansalta on ot1313960- 193485
Purra on kantanut vastuuta täyden kympin arvoisesti
Luottoluokituksen lasku, ennätysvelat ja ennätystyöttömyys siitä muutamana esimerkkinä. Jatkakoon hän hyvin aloittamaans173407- 793347
Persut huutaa taas: "kato! muslimi!"
Persut on lyhyessä ajassa ajaneet läpi kaksi työntekijöiden oikeuksien heikennystä, joita se on aiemmin vastustanut. Pe613244- 493021
- 292915
- 792717
- 542657
- 192377