miksi ei onnistu

kahden tietokantayhteyden l...

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?

4

394

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • The Rat
      • 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

    1. Miksi et irrota otettasi

      Suhteeni?
      Ikävä
      69
      2713
    2. Koko ajan olet

      Senkin suhteen kiusannut. Halut on ihan mielettömät olleet jo pitkään
      Ikävä
      63
      2654
    3. Muutama syy

      Sille miksi IRL kohtaaminen on hänelle vaikeaa
      Ikävä
      68
      1792
    4. Onko kaivatullasi

      Hyvä vai huono huumorintaju?
      Ikävä
      24
      1617
    5. Estitkö sä minut

      Oikeasti. Haluatko, että jätän sun ajattelemisen? :3
      Ikävä
      20
      1550
    6. Tykkään susta

      Elämäni loppuun asti. Olet niin suuresti siihen vaikuttanut. Tykkäsit tai et siitä
      Ikävä
      9
      1480
    7. Onko kaikki hyvin, iso huoli sinusta

      Miten jakselet? Onko sattunut jotain ikävää. Naiselta
      Ikävä
      15
      1392
    8. Millainen meno

      Viikonloppuna? Mulla hirvee vitutus päällänsä. Onko muilla sama tunne??
      Ikävä
      38
      1233
    9. Tiedätkö tykkääkö

      Kaivatustasi siinä mielessä joku muukin kuin sinä itse
      Ikävä
      40
      1203
    10. Onko meillä

      Molemmilla nyt hyvät fiilikset😢ei ainakaan mulla mutta eteenpäin on mentävä😏ikävä on, kait se helpottaa ajan myötä. Ko
      Ikävä
      8
      1197
    Aihe