Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [MySQL]Automatyczne dodawanie nowego rekordu
piekarz
post 31.01.2017, 12:01:36
Post #1





Grupa: Zarejestrowani
Postów: 36
Pomógł: 0
Dołączył: 23.08.2011

Ostrzeżenie: (0%)
-----


Witam.

Jestem początkującym w dziedzinie php/msqli i o ile potrafię tworzyć proste zapytania do bazy danych to przy czymś bardziej skomplikowanym zaczynam się gubić.

I teraz do rzeczy.

Mam tabelę "users" i następujące kolumny: id|name|surname|lokalization|register_date.

I drugą tabelę "user_activites" z kolumnami: userId|posts|votes.

I teraz chciałbym aby przy rejestracji nowego użytkownika w tabli "users" automatycznie został utworzony nowy rekord w tabeli "users_activities" gdzie "userId" było by id użytkownika a w pozostałych kolumnach wartości wynosiły by 0.

Mogę to zrobić przez wykonanie dwóch zapytań do bazy danych. Ale z tego co wyczytałem można zrobić to jednym zapytaniem wykorzystując klucze obce. Niestety pomimo przejrzeniu przejrzeniu wyników google dalej nie wiem jak mam ustawić te klucze w phpMyAdmin.

Bardzo proszę o napisanie jak to wykonać.

Z góry dziękuję.
Go to the top of the page
+Quote Post
markonix
post 31.01.2017, 14:56:31
Post #2





Grupa: Zarejestrowani
Postów: 2 707
Pomógł: 290
Dołączył: 16.12.2008
Skąd: Śląsk

Ostrzeżenie: (0%)
-----


Wykonaj to dwoma zapytaniami, klucze obce oczywiście nałóż ale przy dodawaniu się nie przydadzą. Przydadzą się przy update (rzadkość) i usuwanie (bardzo wygodne).
Zmień też userId na user_id.


--------------------
Go to the top of the page
+Quote Post
viking
post 31.01.2017, 15:06:16
Post #3





Grupa: Zarejestrowani
Postów: 6 376
Pomógł: 1116
Dołączył: 30.08.2006

Ostrzeżenie: (0%)
-----


Możesz to zrobić triggerem ale szczerze nie ma sensu wkładać zer do tabeli dopóki nie ma potrzeby korzystać z tych danych.


--------------------
Go to the top of the page
+Quote Post
piekarz
post 31.01.2017, 20:30:49
Post #4





Grupa: Zarejestrowani
Postów: 36
Pomógł: 0
Dołączył: 23.08.2011

Ostrzeżenie: (0%)
-----


Dziękuję za odpowiedź.
Mam jeszcze pytanie jak ustawić te klucze.
Jestem w phpMyAdmin: W tabeli "users" w zakładce "struktura" i "relations view" mam ustawić "Foreign key constraints" dla kolumny "id" ustawić ograniczenie klucza obcego dla tabeli "user_activites" i kolumny "userId".

Czy tak? Czy może w tabeli "user_activites" mam ustawić ten klucz ze wskazaniem na "users" - "id"?

Dziękuję
Go to the top of the page
+Quote Post
markonix
post 31.01.2017, 21:55:21
Post #5





Grupa: Zarejestrowani
Postów: 2 707
Pomógł: 290
Dołączył: 16.12.2008
Skąd: Śląsk

Ostrzeżenie: (0%)
-----


Ustawiasz klucz w tabeli podrzędnej - on update i delete kaskadową aktualizację i usunięcie.
Czyli jeżeli wyleci user usuwane są także jego wiersze aktywności i inne podrzędne tablice.
Jeżeli chcesz coś zostawić możesz on delete ustawić set null ale i tak nie powiążesz wtedy tego z kimkolwiek więc to mało sensowne.


--------------------
Go to the top of the page
+Quote Post
piekarz
post 1.02.2017, 12:52:23
Post #6





Grupa: Zarejestrowani
Postów: 36
Pomógł: 0
Dołączył: 23.08.2011

Ostrzeżenie: (0%)
-----


Jak próbowałem tak zrobić w phpMyAdmin to wyskoczył błąd.

  1. Zapytanie SQL:
  2.  
  3. ALTER TABLE `user_activities` ADD FOREIGN KEY (`userId`) REFERENCES `test_db`.`users`(`id`) ON DELETE CASCADE ON UPDATE CASCADE;
  4.  
  5. MySQL zwrócił komunikat: Dokumentacja
  6. #1452 - Cannot add or update a child row: a foreign key constraint fails (`test_db`.`#sql-504_2ac`, CONSTRAINT `#sql-504_2ac_ibfk_1` FOREIGN KEY (`userId`) REFERENCES `user_activities` (`id`) ON DELETE CASCADE ON UPDATE CASCADE)


Dlaczego?
Go to the top of the page
+Quote Post
Boshi
post 1.02.2017, 13:02:36
Post #7





Grupa: Zarejestrowani
Postów: 342
Pomógł: 15
Dołączył: 30.08.2011

Ostrzeżenie: (0%)
-----


Prawdopodobnie dlatego, że masz rekordy już dodane i nie może powiązać tego aktualnie.
Go to the top of the page
+Quote Post
Kishin
post 1.02.2017, 13:03:52
Post #8





Grupa: Zarejestrowani
Postów: 148
Pomógł: 17
Dołączył: 20.12.2011

Ostrzeżenie: (0%)
-----


http://stackoverflow.com/questions/5198600...-key-error-1452
Go to the top of the page
+Quote Post
markonix
post 1.02.2017, 14:19:50
Post #9





Grupa: Zarejestrowani
Postów: 2 707
Pomógł: 290
Dołączył: 16.12.2008
Skąd: Śląsk

Ostrzeżenie: (0%)
-----


Odpowiedź @Boshi jest bardziej odpowiednia.
Czemu nie zmieniłeś tych pomieszanych konwencji nazewnictwa?


--------------------
Go to the top of the page
+Quote Post
piekarz
post 1.02.2017, 16:34:41
Post #10





Grupa: Zarejestrowani
Postów: 36
Pomógł: 0
Dołączył: 23.08.2011

Ostrzeżenie: (0%)
-----


Dziękuję za informację.
Co do nazewnictwa, to tylko tak w ramach testów.

Pozdrawiam.
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 29.05.2025 - 16:27