Diskuze: Nahrávanie obrázkov do databáze
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 20 zpráv z 20.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Do DB se obrázek neuložíš, uložíš k němu ID (třeba 4) a pak tento údaj načteš z DB a poté ho dosadíš do adresy zobrazení obrázku (př. /obrazky/(ID z DB).png)
Případně si obrázek můžeš převést do base64 a uložit do DB.
Obrázek se dá do DB uložit do datového typu BLOB. Hodí se to pro náhledy, ale pro velké obrázky už moc ne. Souborový systém je pro ně mnohem vhodnější. Alternativou jsou ještě některé NoSQL databáze.
Když už dáváte i--, tak uveďte důvod !
Žádnou adresu do db nenapíšeš, uložíš tam pouze ID obrázku. Pak to ID z DB SELECTneš a do HTML tagu pomocí PHP vložíš proměnnou do odkazu.
Dobře. Do DB můžeš nahrat "cokoliv" video, obrázek. Stačí takhle ?
Kit myslím že to tvoje riešenie by som asi skúsil. Pretože robiť premennú pre každý obrázok asi nene... Jde o to že to nevím ja k nahrat. BLOB nastavím rozmery sú len 25x25 takže dosť malé obrázky. Môžem ten obrázok nejak rovno vložiť do datbaázy alebo musím vytvoriť formuolr na upload ? Protože ten formulár mi práve chýba.
Obrázky se do DB opravdu obvykle neukládají, uložíš si je do složky na FTP pod nějaké ID, jak již ti bylo řečeno.
Zde ti ukáži jak to myslí Madara a jak to dělám i já.
Na stránce máš upload formulář (odkaz: http://www.w3schools.com/…e_upload.asp ).
Když soubor nahráváš na web udělej si na něj odkaz v
databázi například takto:
Potřebná tabulka -> název tabulky: FILES
ID_FILES | FILES
(ID_FILES - id souboru v db, FILES - název souboru)
Toto používám při výpisu náhledu článků atp.
A pří výpisu (například pomocí while, foreach)
akorát k tagu img připíšeš array ve kterém
jsou uložená data z db. Příklad tagu img:
$cesta = 'images';
while() //nebo foreach pro výpis z tabulky
{
echo "<img src='$cesta/$data[1]'>";
}
$data -> array při výpisu -> $data[0] je ID, $data[1] je název souboru
Snad jsem to popsal dost jasně.
Budeš chtít ty obrázky zobrazovat jako ikony? V tom případě by se daly generovat inline přímo do HTML.
Doufám, že to nejsou obrázky související s designem stránky. Ty patří do CSS.
Na ten formulář se podíváme, až si ujasníme, k čemu toto netypické řešení vlastně potřebuješ.
Profilovým obrázkům je obvykle nejlépe v adresáři na disku. Už kvůli cache v proxy severech a také v prohlížečích, které dokáží načítání takových obrázků významně urychlit. Když avatary uložíš do databáze, tak si zpravidla moc nepomůžeš, protože bez těch cache ti padne výkon. Přece jen cesta Apache->PHP->Databáze->PHP->Apache je o něco delší, než když to řeší Apache ve vlastní režii.
jestli to chceš vidět na kódu tak tady ho máš ():
$query = mysql_query("SELECT * FROM `users` WHERE name='jmeno'");
while($row = mysql_fetch_array($query))
{
echo "<img src='avatar".$row['avatarID'].".png'>";
}
Chybí ti tam parametr se jménem uživatele
$select = $pdo->prepare("SELECT * FROM `users` WHERE name=?");
$select->execute(array($jmeno));
foreach ($select->fetchAll() as $row) {
echo "<img src=\"avatar$row[avatarID].png\">";
}
Těď sem tě moc nepochopil. mám tam
"name='jmeno'"
Jen taková technická - k čemu cyklus, když se má vyhledat jen jeden řádek?
Já to takhle používám už dva roky a občas sem dumal nad tím, jak to udělat bez cyklu, ale jestli ti jde o rychlost, tak žádný problém nebyl
Úplně jednoduše - prostě ten while (nebo foreach) vyhoď. O rychlost mi nešlo (změna je nepatrná), ale spíše o to, že je cyklus prostě zbytečný, když hledáš jen jeden řádek.
Zobrazeno 20 zpráv z 20.