Skocz do zawartości
Zamknięcie Forum PC LAB

Szanowny Użytkowniku,

Informujemy, że za 30 dni tj. 30 listopada 2024 r. serwis internetowy Forum PC LAB zostanie zamknięty.

Administrator Serwisu Forum PC LAB - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie: wypowiada całość usług Serwisu Forum PC LAB z zachowaniem miesięcznego okresu wypowiedzenia.

Administrator Serwisu Forum PC LAB informuje, że:

  1. Z dniem 29 listopada 2024 r. zakończy się świadczenie wszystkich usług Serwisu Forum PC LAB. Ważną przyczyną uzasadniającą wypowiedzenie jest zamknięcie Serwisu Forum PC LAB
  2. Dotychczas zamowione przez Użytkownika usługi Serwisu Forum PC LAB będą świadczone w okresie wypowiedzenia tj. do dnia 29 listopada 2024 r.
  3. Po ogłoszeniu zamknięcia Serwisu Forum od dnia 30 października 2024 r. zakładanie nowych kont w serwisie Forum PC LAB nie będzie możliwe
  4. Wraz z zamknięciem Serwisu Forum PC LAB, tj. dnia 29 listopada 2024 r. nie będzie już dostępny katalog treści Forum PC LAB. Do tego czasu Użytkownicy Forum PC LAB mają dostęp do swoich treści w zakładce "Profil", gdzie mają możliwość ich skopiowania lub archiwizowania w formie screenshotów.
  5. Administrator danych osobowych Użytkowników - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie zapewnia realizację praw podmiotów danych osobowych przez cały okres świadczenia usług Serwisu Forum PC LAB. Szczegółowe informacje znajdziesz w Polityce Prywatności

Administrator informuje, iż wraz z zamknięciem Serwisu Forum PC LAB, dane osobowe Użytkowników Serwisu Forum PC LAB zostaną trwale usunięte ze względu na brak podstawy ich dalszego przetwarzania. Proces trwałego usuwania danych z kopii zapasowych może przekroczyć termin zamknięcia Forum PC LAB o kilka miesięcy. Wyjątek może stanowić przetwarzanie danych użytkownika do czasu zakończenia toczących się postepowań.

Temat został przeniesiony do archiwum

Ten temat przebywa obecnie w archiwum. Dodawanie nowych odpowiedzi zostało zablokowane.

Pieciek

[PHP][SQL] Koszyk z cechami produktów

Rekomendowane odpowiedzi

Witam,

Próbuję sobie wydłubać koszyk sklepu na sesjach, przerabiam gotowy skrypt, ale problem jest w tym, że nie mam pojęcia gdzie, co i jak przerobić, by rozróżniał mi cechy produktu.

 

A konkretniej - skrypt operuje na ID produktu tylko i wyłącznie, a ja chcę do np. koszulki TEST dodać możliwość wyboru rozmiaru, tak by dodał mi koszulkę TEST o rozmiarze L, i też koszulkę TEST o rozmiarze XL, a jako że koszulka TEST obojętnie w jakim rozmiarze ma to samo ID w tabeli - zawsze jest tylko aktualizowany stan koszyka o ilość i ostatnio wybrany rozmiar

 

plik index.php:

 

<?
session_start();
?>

<?='<?xml version="1.0" encoding="utf-8"?>';?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
 "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="pl"><head>
<meta http-equiv="Content-type" content="text/html; charset=iso-8859-2" />
<title>tytuł strony</title></head><body>

<p><b>Wybierz towar ze sklepu</b> / <a href="koszyk.php">koszyk</a></p>
<?
//rozbijanie po przecinkach
$rozmiary = "XS,S,M,L,XL,XXL,XXXL";
$ilosci = "100 szt,200 szt,500 szt";

$tablicarozmiarow = explode(",", $rozmiary);
$tablicailosci = explode(",", $ilosci);

$ilerozmiarow=count($tablicarozmiarow);
$ileilosci = count($tablicailosci);


$sql_serwer = "";
$sql_login  = "";
$sql_haslo  = "";
$sql_baza   = "";
$sql_tabela = "produkty";

if (mysql_connect($sql_serwer, $sql_login, $sql_haslo)
 and mysql_select_db($sql_baza)) {
 $wynik = mysql_query("SELECT * FROM $sql_tabela");
 mysql_close();
}

if ($wynik) {

 echo "<table>";
 echo "<tr><th>produkt</th><th>rozmiar</th><th>cena</th><th> </th></tr>";
 while($dane = mysql_fetch_array($wynik)) {
   $id = $dane["id"];
   $towar = $dane["towar"];
   $cena = $dane["cena"];
 echo "<form action=\"koszyk.php?id=$id\" method=\"GET\">";
 echo '<input type="hidden" name="id" value="'.$id.'" />';
   echo "<tr><td>$towar</td>";

 echo "<td><select name='rozmiar'>";
	for ($i=0; $i <$ilerozmiarow; $i++)
	   {
	    echo "<option value=\"$tablicarozmiarow[$i]\">$tablicarozmiarow[$i]</option>";
	   }
	echo "</select></td>";

 echo "<td>$cena zł</td>";
   echo "<td><input type=\"submit\" value=\"dodaj do koszyka\" /></td>";


 echo "</tr>";
 echo "</form>";
}
 echo "</table>";
}
?>

</body>
</html>

 

plik koszyk.php:

 

<?
session_start();
?>
<?='<?xml version="1.0" encoding="utf-8"?>';?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
 "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="pl"><head>
<meta http-equiv="Content-type" content="text/html; charset=iso-8859-2" />
<title>tytuł strony</title></head><body>

<p><b>Koszyk</b> / <a href="index.php">wróć do towarów</a>/ <a href="dane.php">dane</a></p>

<?

$sql_serwer = "";
$sql_login  = "";
$sql_haslo  = "";
$sql_baza   = "";
$sql_tabela = "produkty";

function odbierz($txt) {
 if (get_magic_quotes_gpc()) $txt = stripslashes($txt);
 return str_replace(array('\\',"'"), array('\\\\',"\'"), trim($txt));
}


$id = odbierz($_REQUEST["id"]);
$sz = isset($_REQUEST["sz"])?number_format($_REQUEST["sz"],0,".",""):"";

if ($id<>"") {
 if (mysql_connect($sql_serwer, $sql_login, $sql_haslo)
   and mysql_select_db($sql_baza)) {
   $wynik = mysql_query("SELECT * FROM $sql_tabela WHERE id='$id'");
   mysql_close();
 }
 if ($wynik and mysql_num_rows($wynik)==1) {
   $dane = mysql_fetch_array($wynik);
   $_SESSION["koszyk"]["$id"]["towar"]=$dane["towar"];
   $_SESSION["koszyk"]["$id"]["cena"]=$dane["cena"];
 $_SESSION["koszyk"]["$id"]["rozmiar"]=$_GET["rozmiar"];

   if ($sz=="") $_SESSION["koszyk"]["$id"]["ile"]++;
   else if ($sz>=1) $_SESSION["koszyk"]["$id"]["ile"]=$sz;
   else if ($sz<=0) unset($_SESSION["koszyk"]["$id"]);
 }
}


if (count($_SESSION["koszyk"])>0) {
 echo "<table border=\"1\">
 <colgroup>
   <col />
   <col align=\"right\" />
   <col align=\"center\" />
   <col align=\"right\" />
 </colgroup>
 <tr><th>towar</th><th>cena</th><th>sztuk</th><th>łącznie</th></tr>";

 foreach($_SESSION["koszyk"] as $indeks=>$kosz) {
  $laczniesztuk +=$kosz["ile"];
 	$cena = $kosz["cena"];


$towar .= $kosz["towar"];
$towar .= "<br />Rozmiar: ";
  $towar .= $kosz["rozmiar"];
   echo "<tr>";
   echo "<td>$towar</td>";

   echo "<td>$cena zł</td>";

   echo "<td>
   <form action=\"koszyk.php\" method=\"get\" style=\"display:inline;\">
     <div style=\"display:inline;\">
     <input type=\"hidden\" name=\"id\" value=\"$indeks\" />
     <input type=\"text\" name=\"sz\" value=\"{$kosz["ile"]}\"
       style=\"width:25px;\" />
     <input type=\"submit\" value=\"zmień\" style=\"width:45px;\" />
   </div></form>
   <form action=\"koszyk.php\" method=\"get\" style=\"display:inline;\">
     <div style=\"display:inline;\">
     <input type=\"hidden\" name=\"id\" value=\"$indeks\" />
     <input type=\"hidden\" name=\"sz\" value=\"0\"
       style=\"width:25px;\" />
     <input type=\"submit\" value=\"usuń\" style=\"width:45px;\" />
   </div></form>
   </td>";
   echo "<td>".number_format($cena*$kosz["ile"],2,".","");
   echo " zł</td>";

   echo "</tr>";
   $lacznie +=$cena*$kosz["ile"];
 $laczniesztuk +=$kosz["ile"];
 }
 echo "<tr><td colspan=\"3\" align=\"right\">
 w sumie: </td><td>";
 echo number_format($lacznie,2,".","")." zł</td></tr>";
 echo "</table>";
} else echo "<p>Koszyk jest pusty...</p>";
?>

</body>
</html>

 

a działa toto tak: https://yanshost.yapis.net/perfumy/index.php

 

Prosiłbym o podpowiedź jak to zrobić i z góry bardzo dziękuję :))

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Zrób sobie w bazie tabele `cart` z polami `id`, `account`, `product`, `size`, `amount` i na tym operuj.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Tylko że tych produktów w tej opcji bazy będzie od cholery, mam z 10 modeli koszulek, każda ma 10 kolorów i 7 rozmiarówek, będzie tego w tysiącach :(

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

ale koszyk masz przecież chwilowy

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

ale trzeba wszystkie produkty we wszystkich konfiguracjach kolorów i rozmiarów dodać osobno do bazy czyli strony ze "sklepem" :) troche dużo tego jest, myślałem by sobie to uproscić tak jak w standardowych sklepach, wchodze do produktu już w danym kolorze (1/3 produktów mniej do dodania), i tam z selecta wybieram rozmiar. Tylko że ten skrypt, który wkleiłem uwzględnia tylko id produktu, i czy koszulka X będzie w rozmiarze L czy XXL, to i tak będzie miała ten sam id. Trzeba by tam było jakoś dodać COŚ (nie jestem mocny w php niestety, tak biore na chłopski rozum) by koszyk rozróżniał czy koszulka o id=1 i rozmiar=XXL już jest w koszyku (do koszyka przekazuję dwie zmiennie - id produktu i rozmiar), jesli jest, to zwieksza ilość o 1, jeśli nie, to dodaje, nawet jeśli to id już jest w koszyku ale z inną zmienną rozmiar. Tak by to było w teorii, ale nie wiem jak to wcielić w życie, bo sprawdza tylko id. Coś trzeba gdzieś dodać...

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Ja to zawsze robię tak:

 

tabela `products` z `id`, (varchar) `name`, (int) `price`,

przykładowy rekord: 1; Koszulka; 2500; (cena w groszach)

 

później tabela np. `products_variants` z polami `id`, (int) `product`, (int) `color`, (int) `size`,

przykładowy rekord: 1; 1; 1; 1; (zawiera koszulkę 1 o rozmiarze 1 i kolorze 1)

tutaj można jeszcze dodać pole `amount`, aby wiedzieć ile tego towaru mamy na sklepie lub czy klient może to zamówić

 

dodatkowo tabele w zależności od potrzeb:

`colors` z polami `id`, (varchar) `name`, (varchar) `hex`

przykładowo: 1; Biały; #ffffff; (Hex żeby wyświetlić kolor w formie np. ikonki)

 

`sizes` z polami `id`, (varchar) `name`

przykładowo: 1; XXL;

 

Na końcu zamiast tej tabeli `cart` robisz sobie faktycznie sesję zawierającą tablicę składającą się z 'product' (id wariantu) i 'amount' (ilość tego wariantu).

 

Wszystko ładnie sklepiasz za pomocą JOIN:

http://www.elektroonline.pl/a/2460,Komenda-JOIN-w-bazach-danych-MYSQL

 

Lub mniej profesjonalne za pomocą pętli.

 

Niedawno robiłem sklep dla kobiety z bielizną, która musiała wprowadzić parę tysięcy swoich produktów i jakoś nie marudziła.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

  • Ostatnio przeglądający   0 użytkowników

    Brak zarejestrowanych użytkowników przeglądających tę stronę.

×
×
  • Dodaj nową pozycję...