phpbar.de logo

Mailinglisten-Archive

[php] Grosse datenbanken.... !?

[php] Grosse datenbanken.... !?

Thomas Feyrer Dante_(at)_altmuehlnet.de
Fri, 09 Apr 1999 14:52:53 +0200


At 09:29 09.04.99 +0200, Alexander Meis wrote:
Hi,
>>Falls es nicht zu viele user werden sollten, kannst du sie in eine tabelle
>>reinhaun, falls es dann aber performance-probleme gibt, würde ich die
>>adresse in eine andere tabelle geben (mit user-id)...
>
>hmm ich hoffe mal das es möglichst viele werden ... ich gehe mal von über
>10.000 aus...
>zwar nciht am ersten tag aber ich hoffe doch im lauffe der zeit....

Und wie oft würden die dann schätzungsweise neue Gebote gegeben werden?
Wenn es zu Spitzenzeiten nicht mehr als 5 pro 15 min. sind, dürfte es
eigentlich kein allzugrosses Problem werden.

>>Also wenn du z.b.
>>mysql_query( "SELECT * FROM artikel,gebote,user WHERE
>>artikel.artikelid=gebote.artikelid AND artikel.type='bild'" );
>>machst, würdest du halt dann als output alle bilder incl. der user, deren
>>adresse und der gebote bekommen, oder hab ich irgendwo nen fehler bzw. muss
>>ich zuvor noch was machen (ausser mysql_connect und mysql_select_db) ?

Also die Abfrage oben ist extrem unrentabel und eigentlich nur für den
Admin interresant (war ja auch nur ein Bsp.)
Ausserdem hab ich was vergessen, richtig müsste es lauten:
mysql_query( "SELECT * FROM artikel,gebote,user WHERE
artikel.artikelid=gebote.artikelid AND gebote.userid=user.userid AND
artikel.type='bild'" );

>hmm wie komme ich denn dann zb an die ausgabe der strasse des users ran ?
>oder an die beschreibung des artikels ?

Das kommt auf die Tabellen-Definition an, wenn du z.b. folgendes hast:
artikel: artikelid, type, beschreibung, startpreis
gebote: artikelid, userid, gebot
user: userid, name, email, adresse
dann die obere ausgabe nun in $result eingelesen wurde ein:
while( $row = mysql_fetch_row( $result ) )
dann hättest du bei jedem durchlauf von while im array $row folgendes:
$row = array( "artikelid", "type", "beschreibung", "startpreis",
"artikelid", "userid", "gebot", "userid", "name", "email", "adresse" );
durch ein:
list( $artikelid, $type, $beschreibung, $startpreis, $artikelid, $userid,
$gebot, $userid, $name, $email, $adresse ) = $row;
könntest du dann die mehrfach vorkommenden eliminieren...

Gruss
  Domas



php::bar PHP Wiki   -   Listenarchive