Współpraca PHP z MySql

Podobne dokumenty
Współpraca PHP z MySql cz.2

Zajęcia 13 wykorzystanie MySQL w PHP cz. 2

Zajęcia 11 wykorzystanie MySQL w PHP

Bazy danych w PHP dla początkujących

ZAAWANSOWANE BAZY DANYCH I HURTOWNIE DANYCH MySQL, PHP

Systemy internetowe. Wykład 4 mysql. West Pomeranian University of Technology, Szczecin; Faculty of Computer Science

Język PHP. Studium Podyplomowe Sieci Komputerowe i Aplikacje Internetowe. v1.7, 2007/11/23

SIECI KOMPUTEROWE I BAZY DANYCH

Bazy Danych - Instrukcja do Ćwiczenia laboratoryjnego nr Prosta obsługa Bazy w PHP

Internetowe bazy danych

Bazy Danych - Instrukcja do Ćwiczenia laboratoryjnego nr 8

Wprowadzenie do Internetu Zajęcia 5

Język SQL, zajęcia nr 1

Autor: Joanna Karwowska

Dynamiczne generowanie pliku PDF

Aplikacje internetowe

Projekt strony internetowej firmy organizującej przyjęcia

Baza danych do przechowywania użytkowników

Internetowe bazy danych

PHP + MySQL w laboratorium (1)

Obiektowe bazy danych

Formularze HTML. dr Radosław Matusik. radmat

strukturalny język zapytań używany do tworzenia i modyfikowania baz danych oraz do umieszczania i pobierania danych z baz danych

Wydział Elektrotechniki, Informatyki i Telekomunikacji Instytut Informatyki i Elektroniki

Bazy danych. dr Radosław Matusik. radmat

ASP.NET MVC. Podstawy. Zaawansowane programowanie internetowe Instrukcja nr 3

Zagadnienia. Konstrukcja bibliotek mysql i mysqli w PHP. Dynamiczne generowanie stron. Połączenie, zapytanie i sesja

Internetowe bazy danych

Systemy internetowe Wykład 4 mysql

Wykład 5. SQL praca z tabelami 2

Rejestracja i Logowania - PHP/MySQL

MVC w praktyce tworzymy system artykułów. cz. 2

Sprawdzenie czy połączenie przebiegło poprawnie if (mysqli_connect_errno()) { echo Błąd; Połączenie z bazą danych nie powiodło się.

Wykład 5: PHP: praca z bazą danych MySQL

Bazy danych i usługi sieciowe

Ćwiczenie zapytań języka bazy danych PostgreSQL

Bazy Danych i Usługi Sieciowe

Szablon główny (plik guestbook.php) będzie miał postać:

Laboratorium nr 4. Temat: SQL część II. Polecenia DML

Michał Bielecki, KNI 'BIOS'

Języki programowania wysokiego poziomu. PHP cz.4. Bazy danych

Instytut Mechaniki i Inżynierii Obliczeniowej Wydział Mechaniczny Technologiczny Politechnika Śląska

Tworzenie serwisów WWW. Pierwsza pomoc

PHP może zostać rozszerzony o mechanizmy dostępu do różnych baz danych:

Ćwiczenia laboratoryjne nr 11 Bazy danych i SQL.

Hurtownia Świętego Mikołaja projekt bazy danych

JAK W NAGŁÓWKU STRONY LUB BLOGA

Dostęp do baz danych z serwisu www - PHP. Wydział Fizyki i Informatyki Stosowanej Joanna Paszkowska, 4 rok FK

Bazy Danych i Usługi Sieciowe

Bazy danych. Bazy danych. Podstawy języka SQL. Dr inż. Paweł Kasprowski.

Relacyjne bazy danych. Podstawy SQL

Podstawowe wykorzystanie Hibernate

Podstawy programowania (PHP/Java)

Wykład 05 Bazy danych

mysql> UPDATE user SET Password=PASSWORD('pass') WHERE user='root'; Query OK, 2 rows affected (0.05 sec) Rows matched: 2 Changed: 2 Warnings: 0

Programowanie w SQL procedury i funkcje. UWAGA: Proszę nie zapominać o prefiksowaniu nazw obiektów ciągiem [OLIMP\{nr indeksu}] Funkcje użytkownika

SQL (ang. Structured Query Language)

Aplikacje WWW - laboratorium

Instalacja MySQL.

Ćwiczenie 7 Komponent IBQuery - uruchamianie zapytań aktualizujących. 1. Przygotować w nowym katalogu aplikację do aktualizacji bazy SKOKI.GDB.

BAZA DANYCH SIECI HOTELI

Kierunek: ETI Przedmiot: Programowanie w środowisku RAD - Delphi Rok III Semestr 5

Plan bazy: Kod zakładający bazę danych: DROP TABLE noclegi CASCADE; CREATE TABLE noclegi( id_noclegu SERIAL NOT NULL,

Wykład 8. SQL praca z tabelami 5

Relacyjne bazy danych. Podstawy SQL

Internetowe bazy danych

Przykłady najlepiej wykonywać od razu na bazie i eksperymentować z nimi.

Informatyka (5) SQL. dr inż. Katarzyna Palikowska Katedra Transportu Szynowego p. 4 Hydro

Projektowanie systemów baz danych

Kurs. Podstawy MySQL

Struktura drzewa w MySQL. Michał Tyszczenko

Sprzeg podstawowy do baz danych w PHP Mateusz Sowa, 2007

Bazy danych SQL Server 2005

Baza danych Uczniowie.mdb

Język SQL, zajęcia nr 2

Imię i Nazwisko Data Ocena. Laboratorium 7

a) ile wynosiła populacja najbardziej i najmniej ludnego z województw (oraz jakie były ich nazwy)

Język DML. Instrukcje DML w różnych implementacjach SQL są bardzo podobne. Podstawowymi instrukcjami DML są: SELECT INSERT UPDATE DELETE

Aplikacje WWW - laboratorium

Programowanie MSQL. show databases; - pokazanie jakie bazy danych są dostępne na koncie

Przykład programu w PHP. Wykład10.PHP ciągdalszy,str.1

Bazy danych. dr inż. Arkadiusz Mirakowski

Zaawansowane bazy danych i hurtownie danych

Projekt-bazy danych Poczta

1. Połączenie z bazą danych. W wybranym edytorze tworzymy plik sqltest.py i umieszczamy w nim poniższy kod. #!/usr/bin/python3 import sqlite3

Bazy danych. Dr inż. Paweł Kasprowski

Referat z przedmiotu Technologie Internetowe SPIS TREŚCI

SSK - Techniki Internetowe

Wykład 5 funkcje i procedury pamiętane widoki (perspektywy) wyzwalacze

SYSTEMY TELEINFORMATYCZNE

Wstęp... 2 Podstawy teoretyczne zastosowane technologie Środowisko pracy... 3 Apache HTTP Server... 3 Baza danych MySQL

Bazy Danych i Usługi Sieciowe

Bazy danych 7. SQL podstawy

Bazy danych. Polecenia SQL

1. Tworzenie tabeli. 2. Umieszczanie danych w tabeli

Odnawialne Źródła Energii I rok. Tutorial PostgreSQL

TECHNOLOGIE SIECI WEB

Bazy danych dla producenta mebli tapicerowanych. Bartosz Janiak Marcin Sikora Wrocław r.

Transkrypt:

Współpraca PHP z MySql 1. Wyświetlanie danych z bazy: show.php mysql_select_db("login") or die('nie można wybrać bazy danych: '. if($link) echo "Połączono z bazą<br>"; $zapytanie="select * FROM studenci"; <p><b>w bazie są następujący studenci:</b></p> <table border="1" width="100%" class="danestudentow"> <tr> <td><b>id</b></td> <td width="70"><b>imię:</b> </td> <td width="70"><b>imię drugie:</b> </td> <td width="90"><b>nazwisko:</b> </td> <td width="80"><b>data urodzenia:</b> </td> <td width="30"><b>płeć:</b> </td> <td width="40"><b>wiek:</b> </td> <td><b>miasto_id:</b> </td> <td><b>kierunek_id:</b> </td></tr> while ($line = mysql_fetch_array($wynik)) echo "<tr> <td align=\"center\">".$line['id']."</td> <td align=\"left\">".$line['imie']."</td> <td align=\"left\">". $line['imie_drugie']."</td> <td align=\"left\">".$line['nazwisko']."</td> <td align=\"center\">".$line['data_ur']."</td> <td align=\"center\">".$line['plec']."</td> <td align=\"center\">".$line['wiek']."</td> <td align=\"center\">". $line['miasto_id']."</td> <td align=\"center\">". $line['kierunek_id']."</td> </tr>";

2. Usuwanie danych z tabeli mysql_select_db("baza") or die('nie można wybrać bazy danych: '. if(isset($_get["student"])) $usun = "delete from studenci where id=".$_get["student"].""; if(mysql_query($usun)) echo "Usunięto studenta o id: "."<b>". $_GET["student"]."</b>"; $zapytanie="select * FROM studenci"; <table border="1" width="100%"> <tr> <td><b>id</b> </td> <td width="110"><b>imię:</b> </td> <td width="110"><b>imię drugie:</b> </td> <td width="130"><b>nazwisko:</b> </td> <td><b>data urodzenia:</b> </td> <td><b>płeć:</b> </td> <td>usuń:</td> </tr> while ($line = mysql_fetch_array($wynik)) echo "<tr> <td align=\"center\">".$line['id']."</td> <td align=\"left\">".$line['imie']."</td> <td align=\"left\">". $line['imie_drugie']."</td> <td align=\"left\">".$line['nazwisko']."</td> <td align=\"center\">".$line['data_ur']."</td> <td align=\"center\">".$line['plec']."</td> <td align=\"center\"><a href=\"index.php? id=5&student=".$line['id']."\">usuń</a></td> </tr>";

3. Dodawanie danych do bazy (add.php i addaction.php) add.php <form action="addaction.php" method="post"> <table> <tr><td width="120"><b>imię:</b> </td><td width="200"><input type= "text" name="imie" /></td></tr> <tr><td width="120"><b>imię drugie:</b> </td><td width="200"><inpu t type="text" name="imie_drugie" /></td></tr> <tr><td width="120"><b>nazwisko:</b> </td><td width="200"><input t ype="text" name="nazwisko" /></td></tr> <tr><td width="120"><b>data urodzenia:</b> </td><td width="200"><i nput type="text" name="data_ur" /></td></tr> <tr><td width="120"><b>płeć:</b> </td><td width="200"><input type= "text" name="plec" /></td></tr> <tr><td width="120"><b>wiek:</b> </td><td width="200"><input type= "text" name="wiek" /></td></tr> <tr><td width="120"><b>miasto_id:</b> </td><td width="200"><input type="text" name="miasto_id" /></td></tr> <tr><td width="120"><b>kierunek_id:</b> </td><td width="200"><inpu t type="text" name="kierunek_id" /></td></tr> <tr><td></td><td><input type="submit" value="dodaj osobę" /></td>< /tr> </form> addaction.php <p><b>następująca osoba zostanie dodana do bazy:</b></p> <table border="1"> <tr><td width="120"><b>imię:</b> </td><td width="200"><? echo $_PO ST["imie"];</td></tr> <tr><td width="120"><b>imię drugie:</b> </td><td width="200"><? ec ho $_POST["imie_drugie"];</td></tr> <tr><td width="120"><b>nazwisko:</b> </td><td width="200"><? echo $_POST["nazwisko"];</td></tr> <tr><td width="120"><b>data urodzenia:</b> </td><td width="200"><? echo $_POST["data_ur"]; </td></tr> <tr><td width="120"><b>płeć:</b> </td><td width="200"><? echo $_PO ST["plec"];</td></tr> <tr><td width="120"><b>wiek:</b> </td><td width="200"><? echo $_PO ST["wiek"];</td></tr> <tr><td width="120"><b>miasto_id:</b> </td><td width="200"><? echo $_POST["miasto_id"];</td></tr> <tr><td width="120"><b>kiierunek_id:</b> </td><td width="200"><? e cho $_POST["kierunek_id"];</td></tr>

mysql_select_db("login") or die('nie można wybrać bazy danych: '. if($link) echo "Połączono z bazą"; $zapytanie = "INSERT INTO studenci(imie,imie_drugie,nazwisko,da ta_ur,plec,wiek,miasto_id,kierunek_id) VALUES( '".$_POST["imie"]."', '".$_POST["imie_drugie"]."', '".$_POST["nazwisko"]."', '".$_POST["data_ur"]."', '".$_POST["plec"]."', ".$_POST["wiek"].", ".$_POST["miasto_id"].", ".$_POST["kierunek_id"].")"; echo "<pre>$zapytanie</pre>"; if($wynik) echo "Dane zostały zapisane.<br>"; else echo "Dane nie zostały zapisane.<br>"; Zadanie 1. 1. Poprawić plik show.php, aby zamiast miasto_id, kierunek_id (tzn. liczb) pojawiały się konkretne nazwy miast i kierunków. 2. Dodać walidację w formularzu przyjmującym dane studenta (sprawdzić czy odpowiednie dane, np. imię, nazwisko, data urodzenia, wiek, płeć zostały na pewno wpisane w polu formularza) 5. Edycja danych w bazie za pomocą PHP (edit.php i editaction.php) edit.php

<h2>edytuj studenta</h2> mysql_select_db("login") or die('nie można wybrać bazy danych: '. if(isset($_get["student"])) $zapytanie = "SELECT * FROM studenci where id=".$_get["student"].""; echo $zapytanie; $wyniki = mysql_query($zapytanie); if (!mysql_numrows($wyniki)) echo '<b>brak takiego studenta</b>.'; exit; $wiersz = mysql_fetch_assoc($wyniki); echo ' <form action="index.php?id=401" method="post"> <input type="hidden" name="id" value="'.$_get['student'].'"/> <table border="1"> <tr><td width="120"><b>imię:</b> </td><td width="200"><input t ype="text" name="imie" value="'.$wiersz['imie'].'" /></td></tr> <tr><td width="120"><b>imię drugie:</b> </td><td width="200">< input type="text" name="imie_drugie" value="'. $wiersz['imie_drugie'].'" /></td></tr> <tr><td width="120"><b>nazwisko:</b> </td><td width="200"><inp ut type="text" name="nazwisko" value="'.$wiersz['nazwisko'].'" /> </td></tr> <tr><td width="120"><b>data urodzenia:</b> </td><td width="200 "><input type="text" name="data_ur" value="'.$wiersz['data_ur'].'" /></td></tr> <tr><td width="120"><b>płeć:</b> </td><td width="200"><input t ype="text" name="plec" value="'.$wiersz['plec'].'" /></td></tr> <tr><td width="120"><b>wiek:</b> </td><td width="200"><input t ype="text" name="wiek" value="'.$wiersz['wiek'].'" /></td></tr> <tr><td width="120"><b>miasto_id:</b> </td><td width="200"><in put type="text" name="miasto_id" value="'.$wiersz['miasto_id'].'" /></td></tr> <tr><td width="120"><b>kierunek_id:</b> </td><td width="200">< input type="text" name="kierunek_id" value="'. $wiersz['kierunek_id'].'" /></td></tr> <tr><td></td><td><input type="submit" name="wyslij" value="zmi eń dane" /></td></tr>

</form> '; die(); $zapytanie="select * FROM studenci"; <table border="1" width="100%"> <tr> <td><b>id</b> </td> <td width="110"><b>imię:</b> </td> <td width="110"><b>imię drugie:</b> </td> <td width="130"><b>nazwisko:</b> </td> <td><b>data urodzenia:</b> </td> <td><b>płeć:</b> </td> <td><b>edytuj:</b></td> </tr> while ($line = mysql_fetch_array($wynik)) echo "<tr> <td align=\"center\">".$line['id']."</td> <td align=\"left\">".$line['imie']."</td> <td align=\"left\">". $line['imie_drugie']."</td> <td align=\"left\">".$line['nazwisko']."</td> <td align=\"center\">".$line['data_ur']."</td> <td align=\"center\">".$line['plec']."</td> <td align=\"center\"><a href=\"index.php? id=4&student=".$line['id']."\">edytuj</a></td> </tr>"; editaction.php <h2>edytuj studenta</h2> mysql_select_db("login") or die('nie można wybrać bazy danych: '. if(isset($_post['wyslij']))

$zapytanie = "UPDATE studenci SET imie = '".$_POST["imie"]."', imie_drugie = '".$_POST["imie_drugie"]."', nazwisko = '".$_POST["nazwisko"]."', data_ur = '".$_POST["data_ur"]."', plec = '".$_POST["plec"]."', wiek = ".$_POST["wiek"].", miasto_id = ".$_POST["miasto_id"].", kierunek_id = ".$_POST["kierunek_id"]." WHERE id=".$_post["id"].""; echo "<pre>$zapytanie</pre>"; if($wynik) echo "<b>dane zostały zapisane.</b><br>"; else echo "<b>dane nie zostały zapisane.</b><br>"; Zadanie 2. 1. Dopisać pliki odpowiadające za dodawanie nowych nazw miast i kierunków studiów (analogicznie jak dodawanie studentów) i dołączyć do strony. 2. Dopisać pliki odpowiadające za wyświetlanie nazw miast i kierunków studiów (analogicznie jak wyświetlanie studentów) i dołączyć do strony. 3. Dopisać pliki odpowiadające za edycję nazw miast i kierunków studiów (analogicznie jak edycję studentów) i dołączyć do strony. 6. Przeszukiwanie bazy z poziomu PHP $link = mysql_connect("localhost", "login", "haslo") or die ("Nie można połączyć sięz bazą"); mysql_select_db("login") or die('nie można wybraćbazy danych: '.

<h2>szukaj</h2> <form action="index.php?id=6" method="post"> <table border="1" width="300"> <tr><td><b>nazwisko:</b></td><td><input name="sz_nazwisko" /></td> </tr> <tr><td><b>płeć:</b></td><td><input name="sz_plec" /></td></tr> <tr><td><b>kierunek:</b></td><td><input name="sz_kierunek" /></td> </tr> <tr><td></td><td><input type="submit" value="szukaj" name="szukaj" /></td></tr> </form> <br><br> if(isset($_post["szukaj"])) $zapytanie="select s.*,m.nazwa as mnazwa, k.nazwa as knazwa FROM studenci s, miasto m, kierunek k "; $where = "WHERE s.miasto_id=m.id and s.kierunek_id=k.id"; if(!empty($_post["sz_nazwisko"])) $where.= " and s.nazwisko LIKE '%". $_POST["sz_nazwisko"]."%'"; if(!empty($_post["sz_plec"])) $where.= " and s.plec ='".$_POST["sz_plec"]."'"; if(!empty($_post["sz_kierunek"])) $where.= " and k.nazwa LIKE '%". $_POST["sz_kierunek"]."%'"; $zapytanie.=$where; echo "<pre>".$zapytanie."</pre>"; echo '<p><b>oto lista szukanych studentów:</b></p>'; echo ' <table border="1" class="danestudentow" width="100%"> <tr> <td><b>id</b></td> <td width="70"><b>imię:</b> </td> <td width="70"><b>imię drugie:</b> </td>

<td width="90"><b>nazwisko:</b> </td> <td width="80"><b>data urodzenia:</b> </td> <td width="30"><b>płeć:</b> </td> <td width="40"><b>wiek:</b> </td> <td><b>miasto:</b> </td> <td><b>kierunek:</b> </td></tr>'; while ($line = mysql_fetch_array($wynik)) echo "<tr> <td align=\"center\">".$line['id']."</td> <td align=\"left\">".$line['imie']."</td> <td align=\"left\">". $line['imie_drugie']."</td> <td align=\"left\">".$line['nazwisko']."</td> <td align=\"center\">".$line['data_ur']."</td> <td align=\"center\">".$line['plec']."</td> <td align=\"center\">".$line['wiek']."</td> <td align=\"center\">".$line['mnazwa']."</td> <td align=\"center\">".$line['knazwa']."</td> </tr>"; echo ''; Zadanie 3. Poprawić wyszukiwarkę tak, aby można było wyszukiwać po wszystkich polach.