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

wyświetlanie wpisów z bazy danych - PHP

Object Storage Arubacloud
0 głosów
758 wizyt
pytanie zadane 7 listopada 2017 w PHP przez Jake Obywatel (1,820 p.)

Witam, tworzę projekt PHP+mysql i chciałbym zrobić pętlę do wyświetlania wpisów - jak na razie mam coś takiego (wklejam cały kod aby oszczędzić wam czarowania z fusów)

function ile() {	
	mysqli_report(MYSQLI_REPORT_STRICT);
	try {
			$db_connect = mysqli_connect(db_host,db_user,db_password,db_name);
		if ($db_connect->connect_errno!=0){
			throw new Exception(mysqli_connect_errno());
		} else {						
			$result = mysqli_query($db_connect, "SELECT * FROM jake_posts");
			$rows = mysqli_num_rows($result);
			if ($rows>0) {
				return $rows;
			} else {
				return "Nie znaleziono wpisów!";
			}
			$db_connect->close();
		}
	} catch(Exception $e_db) {
		echo s_server_error;
	}
}
function posts(){
        mysqli_report(MYSQLI_REPORT_STRICT);
	try {
		$db_connect = mysqli_connect(db_host,db_user,db_password,db_name);
		if ($db_connect->connect_errno!=0){
			throw new Exception(mysqli_connect_errno());
		} else {						
			$result = mysqli_query($db_connect, "SELECT * FROM jake_posts");
			$rows = mysqli_num_rows($result);
			if ($rows>0) {
				for ($i = 1; $i <= $rows; $i++){
				$line = mysqli_fetch_assoc($result);
					$post_id = $line['id'];								
				
					echo $post_id;
				}
			} else {
				echo "Nie znaleziono wpisów!";
			}
			$db_connect->close();
		}
	} catch(Exception $e_db) {
		echo s_server_error;
	}
}

jak można by to zoptymalizować aby ograniczyć to do tego co chcę wyświetlić? dokładniej chodzi mi o to że nie chciałbym otwierać kilku połączeń do bazy danych tylko zrobić to raz i później z tego korzystać - może oddzielna funkcja? Nie mam pojęcia, więc proszę o podsunięcie pomysłu jak można to najlepiej zrobić. Jeśli napisałem coś nie jasno przepraszam, dopiero się uczę pisać w php i nie umiem tego dokładnie opisać/nazwać.

1 odpowiedź

+1 głos
odpowiedź 7 listopada 2017 przez efiku Szeryf (75,160 p.)
wybrane 9 listopada 2017 przez Jake
 
Najlepsza

Zastosuj dependency injection i wstrzykuj połączenie z bazą za pomocą argumentu funkcji, ot 1 optymalizacja

 

<?php


function fetchProducts(\PDO $pdo) : array
{
     
     $sql = "SELECT name,price,something FROM products";
     $result = $pdo->query($sql)->fetchAll();

     return $result;

}
 $connection = new PDO(..) // oczywiście odpowiednie zabezpieczenia..

print_r(fetchProducts($connection));

Tadam

kolejna: Użyj na litość PDO + fetchAll i unikaj SELECT * tylko pobieraj to co potrzeba.

komentarz 7 listopada 2017 przez efiku Szeryf (75,160 p.)

Nie wiem skąd się uczysz, ale sugeruję wpisać w google phptherightway 

1
komentarz 7 listopada 2017 przez efiku Szeryf (75,160 p.)
<?php
function fetchPosts(\PDO $pdo) : array
{
   // http://php.net/manual/en/pdostatement.fetchall.php
   $sql = "SELECT id,postTitle,postContent, something FROM jake_posts";
   // In general, the only time that you'll want to catch and handle a query exception
   // is when you want to do something else if the query fails like insert update del
   return $pdo->query($sql)->fetchAll();

}

 

Trochę się głupio czuję minimalizując tą funkcję tak bardzo.. ;P

 

Podobne pytania

0 głosów
2 odpowiedzi 1,432 wizyt
pytanie zadane 31 sierpnia 2015 w PHP przez tytanik2011 Użytkownik (930 p.)
0 głosów
1 odpowiedź 309 wizyt
+1 głos
3 odpowiedzi 2,876 wizyt
pytanie zadane 2 kwietnia 2021 w PHP przez maciek3621 Nowicjusz (180 p.)

92,576 zapytań

141,426 odpowiedzi

319,652 komentarzy

61,961 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!

...