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

question-closed PHP fetch_assoc, free_result, i Notice: Use of undefined constant - assumed '' in

Object Storage Arubacloud
0 głosów
465 wizyt
pytanie zadane 27 września 2017 w PHP przez qwerty723446 Obywatel (1,750 p.)
zamknięte 27 września 2017 przez qwerty723446

Witam. Tworzę ostatnio stronę internetową (moją trzecią lub czwartą w życiu). W tej jako pierwszej chciałem wprowadzić PHP, jednak napotkałem parę problemów przy tworzeniu licznika wejść.

Kod:

<?php

require_once "basedata.php";
$connection = @new mysqli($host, $db_user, $db_password, $db_name);if($connection->connect_errno!=0)
{

echo "Error ".$connection->connect_errno;	
	
}else
{	

$mysql = "SELECT * FROM licznik";
if($result=@$connection->query($mysql))
{
	
	$wejscie_count=$result->num_rows;
 if($wejscie_count>0)
 {
	 
	 $assoc_array1 = $result->fetch_assoc();
	 $nr1 = assoc_array1['wejscie'];
	 $nr2 = $nr1+1;
	 	

if($nr2==0)
{
	
	echo "Błąd licznika";
	
}else
{
	
	$mysql = "UPDATE licznik SET wejscie='$nr2' WHERE wejscie='$nr1'";
	echo "Strona została odwiedzona ".$nr2." razy";


}
	 
	 
	 $result->free_result();
	
	 
 }
	
 if($result=@$connection->query($mysql))
 {
	
	 $result->free_result();
 }
	
}

$connection->close();
}

?>

Tabela licznik składa się z jednej kolumny - wejscie. connection jest dobrze  skonfigurowany.

Błędy: 

Notice: Use of undefined constant assoc_array1 - assumed 'assoc_array1' in D:\Programy\XAMPP\htdocs\str\index.php on line 73

Warning: Illegal string offset 'wejscie' in D:\Programy\XAMPP\htdocs\str\index.php on line 73

Warning: A non-numeric value encountered in D:\Programy\XAMPP\htdocs\str\index.php on line 74
Strona została odwiedzona 1 razy
Fatal error: Uncaught Error: Call to a member function free_result() on boolean in D:\Programy\XAMPP\htdocs\str\index.php:101 Stack trace: #0 {main} thrown in D:\Programy\XAMPP\htdocs\str\index.php on line 101

komentarz zamknięcia: Rozwiązano
komentarz 27 września 2017 przez Tomek Sochacki Ekspert (227,510 p.)
$assoc_array1 = $result->fetch_assoc();
$nr1 = assoc_array1['wejscie'];

//powinno być chyba:
$nr1 = $assoc_array1['wejscie']; //znak dolarka

 

komentarz 27 września 2017 przez qwerty723446 Obywatel (1,750 p.)

Dziękuję za pomoc, ale nie rozwiązuje to tego następnego błędu:

Fatal error: Uncaught Error: Call to a member function free_result() on boolean in D:\Programy\XAMPP\htdocs\str\index.php:101 Stack trace: #0 {main} thrown in D:\Programy\XAMPP\htdocs\str\index.php on line 101

1 odpowiedź

+1 głos
odpowiedź 27 września 2017 przez Chess Szeryf (76,710 p.)
edycja 27 września 2017 przez Chess
$nr1 = assoc_array1['wejscie'];

Popraw na:

$nr1 = $assoc_array1['wejscie'];

Usuń wszystkie "@".

Masz nielegalny string poza "wejscie".

Nie numeryczna wartość encountered.

Zmodyfikuj ten kod pod swoje wymagania:

<?php
 
$connection = new mysqli('localhost', 'root', '', 'zakupy'); 

$sql0 = "select col from teraz";

$result=$connection->query($sql0);
$row = $result->fetch_assoc();
print_r($row);
$hows = $row['col'];
echo $hows++;
$sql = "update teraz set col = {$hows}";

$result2 = $connection->query($sql);

$sql2 = "select * from teraz";

$result3 = $connection->query($sql2);

$row2 = $result3->fetch_assoc();
print_r($row2);

?>

 

komentarz 27 września 2017 przez qwerty723446 Obywatel (1,750 p.)
Jak już można wywnioskować z tego co napisałem, jestem nowy w PHP i nie do końca rozumiem o co chodzi z tym nienumerycznym stringiem.

Podobne pytania

–1 głos
2 odpowiedzi 1,217 wizyt
0 głosów
0 odpowiedzi 669 wizyt
0 głosów
1 odpowiedź 157 wizyt

92,551 zapytań

141,393 odpowiedzi

319,523 komentarzy

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

...