![]() |
![]() ![]() |
![]() |
-Zako- |
![]()
Post
#1
|
Goście ![]() |
Witam,
Chciał bym zaznaczyć ,że dopiero raczkuje w kwestii php dlatego proszę o wyrozumiałość ![]() mam takie tabele :
oraz
Dane do bazy danych wprowadzane są za pomocą formularza (jednocześnie do tabeli książki oraz do tabeli autorzy przy użyciu dwóch zapytań) i tu właśnie pojawia się problem. Zapisując dane chciałbym aby IDautora (auto_increment) w tabeli autorzy, było również jednocześnie zapisywane do pola IDautora w tabeli książki aby utworzyło się powiązanie na podstawie którego mógłbym później wyszukiwać książki na podstawie autora który ją napisał. P.S. Jeżeli logika całego "przedsięwzięcia" jest nieprawidłowa lub niejasno coś nakreśliłem proszę zwrócić mi uwagę |
|
|
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 35 Pomógł: 1 Dołączył: 1.12.2006 Ostrzeżenie: (0%) ![]() ![]() |
A czego nie wiesz? Po prostu dodajesz dane do tych tabel(INSERT INTO) a później wyświetlasz(SELECT) łącząc tabele(JOIN) na te pola.
|
|
|
-Zako- |
![]()
Post
#3
|
Goście ![]() |
A czego nie wiesz? Po prostu dodajesz dane do tych tabel(INSERT INTO) a później wyświetlasz(SELECT) łącząc tabele(JOIN) na te pola. Tak tak, wiem o tym i robię dokładnie tak jak radzisz. Problem w tym ,że dodając dane z poziomu formularza do bazy danych a konkretnie do tabeli książki nie mam w nim (formularzu) pola IDautora ,bo było bo to moim zdaniem bez sensu. Dlatego też akurat te pole w tabeli książki pozostaje puste ,gdy zapisuje dane (INSERT) w tej tabeli i tu właśnie pojawia się pytanie: jak "pobrać" pole IDautora z tabeli autorzy i wstawić jego zawartość również do IDautora w tabeli ksiazki? Podam również przykład żeby troszkę rozjaśnić sytuację: To "roboczy" formularz z którego dane wprowadzane są do bazy : I teraz dane dotyczące książki zostaną zapisane w tabeli o takiej samej nazwie np pod IDksiążki = 4 (auto_increment) ,podobnie dane dotyczące autora tutaj np. IDautora = 5 (auto_increment). Chcąc teraz wyszukiwać dane książki na podstawie autora, IDautora (klucz obcy) w tabeli książki powinno mieć taką samą wartość jak IDautora(klucz główny) w tabeli autorzy czyli 5 (a po zapisaniu danych ma wartość 0 co zresztą jest logiczne bo nigdzie nie podaje jego wartości) Jak więc sprawić by przy zapisie danych ,IDautora (książki) automatycznie przyjmowało wartość z IDautorzy(autorzy)? Teraz to dopiero pewnie zamotałem;) |
|
|
![]()
Post
#4
|
|
![]() Grupa: Zarejestrowani Postów: 97 Pomógł: 13 Dołączył: 26.06.2003 Skąd: Piekary Śląskie Ostrzeżenie: (0%) ![]() ![]() |
mysql_insert_id();
![]() -------------------- This is only game
|
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 63 Pomógł: 0 Dołączył: 1.10.2009 Ostrzeżenie: (0%) ![]() ![]() |
ja bym dal jedna komorke w tabeli idautorzy z imieniem i nazwiskiem, wyszukiwanie zrobi na zasadzie takiej: pobierasz imie io nazwisko autora laczysz te dwa pola (implode) zapytanie SELECT ID FROM AUTORZY WHERE nazwa = to co implodowales, zapisal to do zmiennej w drugim zapoytaniu dodal tylko id ze zmiennej i zapisal w bazie
|
|
|
![]()
Post
#6
|
|
![]() Grupa: Zarejestrowani Postów: 97 Pomógł: 13 Dołączył: 26.06.2003 Skąd: Piekary Śląskie Ostrzeżenie: (0%) ![]() ![]() |
ehh ... a nie prosciej tak niż jakieś szukanie ?
-------------------- This is only game
|
|
|
![]()
Post
#7
|
|
Grupa: Zarejestrowani Postów: 63 Pomógł: 0 Dołączył: 1.10.2009 Ostrzeżenie: (0%) ![]() ![]() |
no ok, a co w momencie kiedy bedzie doawal ksiazke ale nie autora? 1 autor moze miec kilka ksiazek
|
|
|
-Zako- |
![]()
Post
#8
|
Goście ![]() |
ehh ... a nie prosciej tak niż jakieś szukanie ?
mysql_insert_id() - Dziękuje, czegoś takiego właśnie szukałem, pozostaje jeszcze kwestia poruszona przez swiru_ ,z którą postaram sobie w jakiś sposób poradzić (choć nie ukrywam ,że liczę i na Wasze pomysły;)). |
|
|
![]() ![]() |
![]() |
Wersja Lo-Fi | Aktualny czas: 18.07.2025 - 04:19 |