Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

Проблем със SQL заявка в PHP!

Featured Replies

Имам проблем. Имам следната форма:

 <form method="post", action="index.php">
ID <input type="text" name="id"><br>
Name <input type="text" name="name"><br>
Family <input type="text" name="fname"></br>
<input type="submit", value="Edit user"> </br>
</form>

И следният PHP

if ($_POST)
{
	$ide=$_POST["id"];
	$name=$_POST["name"];
	$fname=$_POST["fname"];
	echo($ide);
	$sqli = "UPDATE info ". "SET name = $name ". "WHERE id = $ide" ;
	mysqli_query($conn, $sqli);
}

Променливата $conn съдържа данните за връзка с базата данни.
Искам да взема стойностите от текстовите полета и след POST да ги използвам в UPDATE заявка.
По някаква причина каквото и да пиша, няма UPDATE, освен ако не е цифри. Ако напиша в id полето на формата цифри - ъпдейтва се. Иначе не.
Къде бъркам със синтаксиса? Не се занимавам с PHP, просто исках да опитам нещо.
Като напиша Echo - да, формата съхранява написаното - дали текст, дали число в променливите. Но нещо в заявката не е много ОК.

Редактирано от Гост (преглед на промените)

Когата се записва текст в база данни, в заявката трябва да е ограден в кавички. Също така трябва да се изполва функция която предотвратява проблеми с кавички в текста, например addslashes(). Тоест кодът трябва да е

$ide = addslashes($_POST["id"]);
$name = addslashes($_POST["name"]);
$sqli = "UPDATE info ". "SET name = '$name' ". "WHERE id = '$ide'";

 

Не знам защо с 2 променливи като параметри за ъпдейт не се получава. Допуснах и малко грешки в имената. Не може name=name и $name=name..

Мързеливото решение е с 2 последователни SQL заявки.
Ако се сещаш, дай идея защо не става в една. Тия разбъркани контролери ми бъркат в здравето.
И благодарско за идеята с addslashes.

<?php
return" <form method='post', action='index.php'>
ID <input type='text' name='id'><br>
Name <input type='text' name='nam'><br>
Family <input type='text' name='fname'></br>
<input type='submit', value='Edit user'> </br>
</form>"
?>


 

<?php
if ($_POST)
{
	$ide = addslashes($_POST["id"]);
	//$ide=$_POST["id"];
	$nam = addslashes($_POST["nam"]);
	$fname = addslashes($_POST["fname"]);
	//$name=$_POST["name"];
	//$fname=$_POST["fname"];
	//echo($ide);
	$sqli1 = "UPDATE info ". "SET name = '$nam' ". "WHERE id = '$ide'" ;
	$sqli2 =  "UPDATE info ". "SET family = '$fname' ". "WHERE id = '$ide'" ;
	mysqli_query($conn, $sqli1);
	mysqli_query($conn, $sqli2);
	
	
}
?>

И последен въпрос - кой е най-удачния начин да накарам страницата да се рефрешва след submit и обработка?
JavaScript event listener-а удачен ли е?
п.п Оправих и това
 

$page = $_SERVER['PHP_SELF'];
	echo '<meta http-equiv="Refresh" content="0;' . $page . '">';

 

Редактирано от Гост (преглед на промените)

Как я пишеш тая заявка? Не се пише отделна заявка за всяко поле.

$sqli = "UPDATE info 
SET name = '$nam',
family = '$fname' 
WHERE id = '$ide'" ;

Няма причина да конкатенираш така странно стринговете. Естествено, че може с един стринг.

Редактирано от plamenbm86 (преглед на промените)

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    25%
    Дарени 252.69 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.