Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> PHP codeigniter MVC baza danych, PHP codeigniter MVC baza danych
pmietus4086
post
Post #1





Grupa: Zarejestrowani
Postów: 3
Pomógł: 0
Dołączył: 1.03.2017

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


Witam. Wszytkich jestem tu nowy (IMG:style_emoticons/default/smile.gif)
Chciałbym prosić o pomoc. Mianowicie, zaczynam przygodę z Codeigniter i PHP.
Mam zrobioną bazę w Phpmyadmin mysql i teraz mam tabele, powiedzmy produkty a w niej kolumny: id / magazyn / produkt / szt.
Chciałbym coś takiego napisać, że jak kolumna szt. będzie 0, to ma mi cały wiersz usunąć.

Jak to zrealizować? Co napisać w Controlerze, co w modelu, a co w widoku?
Może mi ktoś to objaśnić? Z góry wielkie dzięki.

Pozdrawiam
Go to the top of the page
+Quote Post
Omenomn
post
Post #2





Grupa: Zarejestrowani
Postów: 77
Pomógł: 0
Dołączył: 4.02.2014

Ostrzeżenie: (20%)
X----


Zacząłbym od angielskiego nazewnictwa.
Następnie dziwnie według mnie chcesz to rozwiązać, uzależniając usunięcie wiersza od wartości kolumny w wierszu.
Jeżeli chcesz usunąć rekord w bazie danych, to tworzysz metodę w kontrolerze np. destroy($id), przyjmującą id wiersza, który chcesz usunąć.
Wywołujesz odpowiedzialny model za tabele, z której chcesz usunąć rekord i usuwasz po id ze zmiennej $id.
Formularz do usuwania tworzysz w widoku.
Usuwanie rekordów należy wykonywać metodą POST, dlatego używasz formularza, a nie zwykły link.

Są tutoriale na temat CodeIgnitera, sam z takich kiedyś korzystałem.
Podsuną Ci wiele rozwiązań i oszczędzisz czas dzięki nim.

Ten post edytował Omenomn 1.03.2017, 21:40:48
Go to the top of the page
+Quote Post
Spawnm
post
Post #3





Grupa: Moderatorzy
Postów: 4 069
Pomógł: 497
Dołączył: 11.05.2007
Skąd: Warszawa




Sprawdź mysql trigger
Go to the top of the page
+Quote Post
pmietus4086
post
Post #4





Grupa: Zarejestrowani
Postów: 3
Pomógł: 0
Dołączył: 1.03.2017

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


Witam
Dlaczego dziwnie , jeżeli mam produkt w bazie danych którego fizycznie nie ma szt = 0 ...to chce go usunąć z bazy ...
nie chcę tworzyć formularza bo ma mi to automatycznie zrobić ...jeżeli osiągnie zero...
trzeba by było napisać zmienną np taką :
  1. DELETE FROM `nazwa_tabeli` WHERE `szt` = 0 ";

tylko nie wiem czy w modelu??
[MySQL][/MySQL]
Go to the top of the page
+Quote Post
Pyton_000
post
Post #5





Grupa: Zarejestrowani
Postów: 8 068
Pomógł: 1414
Dołączył: 26.10.2005

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


Tam gdzie dokonujesz zapisu zmiany stany magazynowego rzucasz event np. "availability_changed" z ID produktu. Potem robisz sobie EventHandler w którym dla przekazanego stanu robisz sobie DELETE j.w tylko dodatkowo z ID przedmiotu. Tyle
Go to the top of the page
+Quote Post
viking
post
Post #6





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

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


Ach te eventy. Później znajdź panie gdzie co się wykonuje bo popodpinane pińcet zdarzeń. Popieram to co napisał Spawnm. Nawet nie musisz ruszać PHP w takim wykonaniu.
Go to the top of the page
+Quote Post
pmietus4086
post
Post #7





Grupa: Zarejestrowani
Postów: 3
Pomógł: 0
Dołączył: 1.03.2017

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


Panowie zrobiłem to tak :
  1. $this->db->query('DELETE FROM notes WHERE `szt` = 0;',array($this->input->post('produkty_id')));

Działa mi to
co na to powiecie (IMG:style_emoticons/default/questionmark.gif) ?
Go to the top of the page
+Quote Post
Pyton_000
post
Post #8





Grupa: Zarejestrowani
Postów: 8 068
Pomógł: 1414
Dołączył: 26.10.2005

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


może być, tylko jeszcze pewnie indeks się przyda na pole `szt`, chyba że masz tam raptem 100 produktów to można olać (IMG:style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post
Omenomn
post
Post #9





Grupa: Zarejestrowani
Postów: 77
Pomógł: 0
Dołączył: 4.02.2014

Ostrzeżenie: (20%)
X----


Cytat
Dlaczego dziwnie , jeżeli mam produkt w bazie danych którego fizycznie nie ma szt = 0 ...to chce go usunąć z bazy ...

Jeżeli czegoś nie ma, to nie powinno tego być w tym przypadku rekordu jak dla mnie, nie znam całej struktury Twojej bazy, także nie będę oceniał.

Trigger też będzie dobrym rozwiązaniem, według mnie (IMG:style_emoticons/default/tongue.gif) odnośnie postu Spawnm'a
Go to the top of the page
+Quote Post
Pyton_000
post
Post #10





Grupa: Zarejestrowani
Postów: 8 068
Pomógł: 1414
Dołączył: 26.10.2005

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


Triggera tak łatwo nie wrzucisz na AWS RDS to tak z ciekawostek.
Go to the top of the page
+Quote Post

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

 



RSS Aktualny czas: 18.10.2025 - 03:22