Diskuze: Vkládání dat do databáze
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Tvůrce
Zobrazeno 16 zpráv z 16.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
$tema=mysql_real_escape_string($_POST['tema']);
$prispevek=mysql_real_escape_string($_POST['prispevek']);
mysql_query("INSERT INTO vtip (tema, prispevek) VALUES ('$tema', '$prispevek');");
Je to trochu komplikovanější, protože v článku je použit starý ovladač MySQL, u kterého to jinak nejde. Už ho nepoužívám.
Okej,2 problémy...
index.php
<?php
$spojeni=mysql_connect('localhost','root','******');
if (!$spojeni) die('Nepodařilo se připojit k databázi "localhost"<br>');
else echo('Připojeno k databázi "localhost"<br>');
$db = mysql_select_db('test',$spojeni);
if (!$db) die('Nepodařilo se připojit k "test"<br>');
else echo('Uspěšně připojeno k "test"<br>');
?>
<form action="pridej.php" method="post">
<input type="text" name="prispevek">
<input type="submit">
</form>
<br><br>
Výsledek:<br>
<?php
$vysledek=mysql_query("SELECT * FROM diskuze",$spojeni);
echo($vysledek);
?>
pridej.php
<?php
$spojeni=mysql_connect('localhost','root','*******');
if (!$spojeni) die('Nepodařilo se připojit k databázi
"localhost"<br>');
else echo('Připojeno k databázi "localhost"<br>');
$db = mysql_select_db('test',$spojeni);
if (!$db) die('Nepodařilo se připojit k "test"<br>');
else echo('Uspěšně připojeno k "test"<br>');
?>
<?php
$datum = StrFTime("%d/%m/%Y %H:%M:%S", Time());
$prispevek = mysql_real_escape_string($_POST['prispevek']);
mysql_query("INSERT INTO diskuze (datum, prispevek) VALUES ('$datum',
'$prispevek');");
?>
koukal jsem tam jak si mě odkázal,vážně tam musí být všechno ?
<?
$spojeni=mysql_connect("localhost","php@localhost","php");
$co="SELECT * FROM adresar";
$navrat=mysql_db_query("mydata", $co, $spojeni);
echo("<table border=\"1\">");
for ($i=0;$i<mysql_num_fields($navrat); $i++){
echo("<td><strong>".mysql_field_name($navrat, $i)."</strong></td>");
}
while (list($meno, $mail) = mysql_fetch_row($navrat)){
echo("<tr><td>$meno</td><td>$mail</td></tr>");
}
echo("</table>");
?>
->DanVitek: Neboj, už píšu další díl. Tam si ukládání zadaných textů do databáze rozebereme podrobněji.
->Kit: středníky se v mysql_query nepíšou (resp. nemusí psát),
doporučuje to i manuál. Něco jiného by samozřejmě bylo
mysql_multi_query.
BTW, co přesně myslíš tím zastaralým ovladačem?
To vážně vypadá hrozně. Asi proto se to tak nepíše. Možná jsem měl pro tebe najít jinou stránku. To víš, tento způsob už nepoužívám, tak to musím hledat.
Navíc ten cyklus "for" je použit nesprávně. Vlastně je zbytečný a zdržující.
Když se to udělá objektově, tak je to mnohem hezčí. Zkus se podívat jinam.
http://www.php.net/…ef.mysql.php
http://www.php.net/…book.pdo.php
Také platí zásada, že se SQL dotazy nemají v jedné funkci (resp. metodě nebo dokonce třídě) míchat s výstupem HTML. To pravidlo tě donutí psát aplikaci hezky.
S ovladačem PDO to pak vypadá ještě lépe.
Na středníky jsem zvyklý z příkazového řádku, když s DB pracuji přímo. Bez středníku se příkaz neprovede. Ovladače z PHP tam ten středník přidávají automaticky. Nebylo to tak vždy a špatně se ty chyby hledaly.
PHP5 má 3 ovladače MySQL:
V PHP5 se doporučuje používat jeden z posledních dvou. Ten první by se už používat neměl.
Co nechápeš? Já jsem se z php.net učil a dnes to dělám úplně jinak.
Napsal bych sem své řešení, ale sdraco by mě zase sprdnul, že nehorázně přetěžuji objekty
Zvoní mi v uších
Co tu pořád řešíte? Četl Dan celý ten seriál? Připojení je tam
jednoduše vysvětlené: http://www.itnetwork.cz/index.php?…
A i dotazy. S objekty bych ho vůbec nezatěžoval.
Proč? S objekty je dobré začít co nejdříve, než vzniknou chybné procedurální návyky.
Ještě je dobré do těch objektů zapojit funkcionální prvky, aby z toho byl ten správný vývojářský guláš
Zobrazeno 16 zpráv z 16.