• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Dodawanie ogłoszeń do relacyjnej bazy danych

Object Storage Arubacloud
0 głosów
438 wizyt
pytanie zadane 13 września 2015 w SQL, bazy danych przez Vermal Nowicjusz (210 p.)
Mam portal ogłoszeniowy na trzech tabelach:

uzytkownik:
id_user
user
pass

ogloszenia:
id_ogl
ogloszenie
cena

relacja:
id_relacji
id_user
id_ogl

Jak miałem wszystko w jednej tabeli to korzystałem z poniższego sposobu dodawania (oparte na formularzu):
$ins = @mysql_query("INSERT INTO uzytkownik SET ogloszenie='$ogloszenie', cena='$cena' WHERE user='$user'");

Proszę o wskazówki albo fragment kodu, który uzupełni jednocześnie tabelę ogloszenia i tabelę relacja. Niestety nie mogę z tym sobie poradzić :/

2 odpowiedzi

+1 głos
odpowiedź 13 września 2015 przez Boshi VIP (100,240 p.)
Musisz wykonać kilka zapytań. Skorzystaj z http://pl.php.net/manual/en/function.mysql-insert-id.php

Przepisz to na pdo albo mysqli.
0 głosów
odpowiedź 13 września 2015 przez mowmiheniek Stary wyjadacz (11,900 p.)

Tak jak napisał Boshi, musisz wykonać kilka zapytań.

Najlepiej przejdź szybko na mysqli lub lepiej na pdo bo mysql już nieaktualne.

A w tym przypadku bym tak zrobił:

$idu = mysql_query("SELECT `id_user` FROM `uzytkownik` WHERE `user`='$user'");
while ($iduser = mysql_fetch_array($idu)) {					
					$iduztkownika=$iduser['id_user'];
}
$ins = mysql_query("INSERT INTO `ogloszenia` SET `ogloszenie`='$ogloszenie', `cena`='$cena'");
$idogl =  mysql_query("SELECT `id_ogl` FROM `ogloszenia` ORDER BY `id_ogl` DESC LIMIT 1);
while ($ido = mysql_fetch_array($idogl)) {					
					$idogoszenia=$ido['id_ogl'];
}
$inr = mysql_query("INSERT INTO `relacja` SET `id_user`='$iduzytkownika', `id_ogl`='$idogloszenia'");

1. Wyciągasz id użytkownika i zapisuję do zmiennej,

2. Dodajesz ogłoszenie,

3. Wyciągasz id ogłoszenia z ostatnio dodanego ogłoszenia  i zapisuję do zmiennej,

4. Dodajesz id użytkownika i id ogłosznia do tabeli relacja na podstawie zapamiętanych zmiennych.

Kod pisany z ręki bez  IDE więc może posiadać błędy. 

komentarz 13 września 2015 przez Boshi VIP (100,240 p.)
Tylko po co? przecież podałem mu funkcję która robi to samo?
komentarz 15 września 2015 przez mowmiheniek Stary wyjadacz (11,900 p.)
Masz rację.

Czyli w punkcie 3 używasz funkcji: mysql_insert_id.

Podobne pytania

0 głosów
1 odpowiedź 2,242 wizyt
pytanie zadane 7 lutego 2017 w SQL, bazy danych przez BlvckFox Gaduła (4,240 p.)
0 głosów
2 odpowiedzi 266 wizyt
pytanie zadane 25 lutego 2016 w SQL, bazy danych przez Filip31411 Dyskutant (8,820 p.)
0 głosów
1 odpowiedź 346 wizyt
pytanie zadane 24 stycznia 2016 w SQL, bazy danych przez kacper777 Nowicjusz (140 p.)

92,632 zapytań

141,500 odpowiedzi

319,879 komentarzy

62,013 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...