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

Przypisanie ID zgłoszenia do komentarza

VPS Starter Arubacloud
0 głosów
311 wizyt
pytanie zadane 16 listopada 2021 w PHP przez IBIALYI Początkujący (250 p.)

Cześć,

Mam problem z dodaniem id komentarza do id zgłoszenia tzn. po utworzeniu zgłoszenia z przypisanym id w bazie danych mogę wejść w jego zawartość i go zaktualizować i chciałbym dodać do tego możliwość dodawania komentarzy przez użytkownika. Problem w tym że nie za bardzo orientuję się jak zaciągnąć id zgłoszenia do sekcji komentarzy tak aby komentarze wyświetlały się w zgłoszeniu na którym zostały dodane.

Kod który udało mi się napisać: 

<?php
include('config\constants.php');
include('config\db.php');
include('comments.php');



date_default_timezone_set('Europe/Warsaw');

if (isset($_GET['task_id'])) {
  $task_id = $_GET['task_id'];

  $sql = "SELECT * FROM tbl_task WHERE task_id = $task_id";

  $res = mysqli_query($conn, $sql);

  if ($res == true) {

    $row = mysqli_fetch_assoc($res);

    $task_name = $row['task_name'];
    $task_description = $row['task_description'];
    $list_id = $row['list_id'];
    $priority = $row['priority'];
    $deadline = $row['deadline'];
  }
} else {
  header('location:index.php');
}
echo $task_description;

?>
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Task Manager</title>
</head>

<body>

  <h3>Update task</h3>

  <form method="POST" action="">
    <table>
      <tr>
        <td>Task name:</td>
        <td><input type="text" name="task_name" value="<?php echo $task_name; ?>" require="requierd" /></td>
      </tr>
      <tr>
        <td>Task Description:</td>
        <td>
          <textarea name="task_description">
<?php echo $task_description; ?>
  </textarea>
        </td>
      </tr>
      <tr>
        <td>Select list:</td>
        <td>
          <select name="list_id">
            <?php
            $conn2 = new mysqli(LOCALHOST, DB_USERNAME, DB_PASSWORD, DB_NAME);
            //Zapytanie wyciagajace liste z db
            $sql2 = "SELECT * FROM tbl_list";
            $res2 = mysqli_query($conn2, $sql2);
            if ($res2 == true) {
              //wyświetl liste
              //count rows
              $count_rows2 = mysqli_num_rows($res2);

              //Sprawdzanie czy lista jest dodana
              if ($count_rows2 > 0) {

                while ($row2 = mysqli_fetch_assoc($res2)) {

                  $list_id_db = $row2['list_id'];
                  $list_name = $row2['list_name'];
            ?>
                  <option <?php if ($list_id_db == $list_id) {
                            echo "selected='selected'";
                          } ?>; value=value="<?php echo $list_id_db; ?>"><?php echo $list_name;   ?></option>
                <?php

                }
              } else {
                ?>
                <option <?php if ($list_id = 0) {
                          echo "selected='selected'";
                        } ?> value="0">None</option>p
            <?php
              }
            }


            ?>
            <option value=value="1">Doing</option>
          </select>
        </td>
      </tr>
      <tr>
        <td>Priority:</td>
        <td>
          <select name="priority">
            <option <?php if ($priority == "High") {
                      echo "selected='selected'";
                    } ?> value="High">High</option>
            <option <?php if ($priority == "Medium") {
                      echo "selected='selected'";
                    } ?> value="Medium">Medium</option>
            <option <?php if ($priority == "Low") {
                      echo "selected='selected'";
                    } ?> value="Low">Low</option>
          </select>
        </td>
      </tr>
      <tr>
        <td>Deadline:</td>
        <td><input type="date" name="deadline" value="<?php echo $deadline; ?>"></td>

      </tr>
      <tr>
        <td><input type="submit" name="submit" value="update"></td>
      </tr>
    </table>
  </form>


  <?php
  if (isset($_POST['submit'])) {

 
    //Dane z form
    $task_name = $_POST['task_name'];
    $task_description = $_POST['task_description'];
    $list_id = $_POST['list_id'];
    $priority = $_POST['priority'];
    $deadline = $_POST['deadline'];

    $conn3 = new mysqli(LOCALHOST, DB_USERNAME, DB_PASSWORD, DB_NAME);

    $sql3 = "UPDATE tbl_task SET 
task_name = '$task_name',
task_description = '$task_description',
priority = '$priority',
deadline = '$deadline'
WHERE
task_id = $task_id
";

    $res3 = mysqli_query($conn3, $sql3);
  }
  ?>

  <?php

 echo "<form method='POST' action='" . setComment($conn) . "'>

    <input type='hidden' name='user_id' value='anonymous'>
    <input type='hidden' name='date' value='" . date('Y-m-d H:i:s') . "'>
    <textarea name='msg'> </textarea><br></br>
    <button type='submit' name='commentSubmit'>Dodaj</button>
  </form>";

  ?>
</body>

</html>

Funkcja z setComment:

<?php

function setComment($conn)
{
 if (isset($_POST['commentSubmit'])) {

  $user_id = $_POST['user_id'];
  $date = $_POST['date'];
  $msg = $_POST['msg'];


  $sql = "INSERT INTO msg (user_id, date, msg, ) VALUES ('$user_id', '$date', '$msg' ) ";

  $res = $conn->query($sql);
 }
}

Zgłoszenia jak i komentarze dodają się poprawnie do swoich tabel w bazie. Sam powyższy kod wymaga jeszcze wielu poprawek. 

1 odpowiedź

+2 głosów
odpowiedź 16 listopada 2021 przez Arkadiusz Waluk Ekspert (287,550 p.)
wybrane 17 listopada 2021 przez IBIALYI
 
Najlepsza
Nie do końca zrozumiałem z czym masz dokładnie problem, z przypisaniem komentarza do danego zgłoszenia? Czy z wyświetleniem komentarzy tylko dla danego zgłoszenia?

W tabeli z komentarzami powinieneś mieć id zgłoszenia (np. task_id). Dodając nowy komentarz podajesz tam zgłoszenia o jakim id się tyczy. Następnie, aby wyciągnąć komentarze tylko do danego zgłoszenia, robisz zapytanie SELECT z WHERE task_id=X - podobnie jak masz to w UPDATE w $sql3.

A kod faktycznie wymaga poprawek, szczególnie zwróciłbym uwagę na brak zabezpieczenia przed sql injection.
komentarz 16 listopada 2021 przez IBIALYI Początkujący (250 p.)
Problem jest z  przypisaniem komentarza do danego zgłoszenia.

Pytanie w $sql3 zapytanie odwoływało się do innej tabeli, sekcja z komentarzami znajduje się w drugiej. Czy w takim wypadku wystarczy odwołać się do dwóch tabel w jednym zapytaniu?
komentarz 16 listopada 2021 przez Arkadiusz Waluk Ekspert (287,550 p.)

Nie, nie w jednym zapytaniu, to był tylko przykład, że trzeba zrobić SELECT podobnie jak ten UPDATE.

W tabeli z komentarzami powinieneś mieć kolumnę task_id, która będzie połączona relacją do id w tabeli tasków. Następnie dodawanie komentarzy powinno wyglądać mniej więcej tak:

INSERT INTO msg (task_id, user_id, date, msg) VALUES ($task_id, '$user_id', '$date', '$msg') 

Gdzie jako $task_id podstawisz id zgłoszenia do którego chcesz dodać komentarz.

Aby pobrać komentarze dla danego zgłoszenia, wystarczy zrobić wtedy SELECT ... WHERE task_id=X, gdzie jako X podstawisz id danego taska.

komentarz 16 listopada 2021 przez IBIALYI Początkujący (250 p.)

Zrobiłem coś takiego:

<?php

function setComment($conn)
{
 if (isset($_POST['commentSubmit'], $_GET['task_id'])) {

  $task_id = $_GET['task_id'];
  $user_id = $_POST['user_id'];
  $date = $_POST['date'];
  $msg = $_POST['msg'];


 echo $sql = "INSERT INTO msg (user_id, task_id, date, msg, ) VALUES ('$user_id', '$task_id', '$date', '$msg' ) WHERE (task_id = $task_id) ";

  $res = $conn->query($sql);
 }
}

Wywołałem zapytanie i wygląda na to że faktycznie id zaciąga się poprawnie

INSERT INTO msg (user_id, task_id, date, msg, ) VALUES ('anonymous', '9', '2021-11-16 20:02:12', ' Test' ) WHERE (task_id = 9)

tylko po tym tabela msg nie aktualizuje się tzn. nie ma żadnych danych po wykonaniu polecenia.

komentarz 16 listopada 2021 przez IBIALYI Początkujący (250 p.)
Poprawne zapytanie
INSERT INTO msg (user_id, task_id, date, msg, ) VALUES ('anonymous', '9', '2021-11-16 20:02:25', ' Działa?' )

 

 

komentarz 16 listopada 2021 przez Arkadiusz Waluk Ekspert (287,550 p.)
Może wystąpił jakiś błąd z bazą, spróbuj go podejrzeć np. przy użyciu https://www.php.net/manual/en/mysqli.error.php

Nie wiem jaka to dokładnie baza i wersja, ale przecinek po msg i przed ) może być problemem, tam już nie ma kolejnej kolumny, więc nie powinno go tam być. Pytanie też czy user_id to kolumna tekstowa, a nie int? Podane zapytanie przechodzi chociażby w phpmyadmin?
1
komentarz 17 listopada 2021 przez IBIALYI Początkujący (250 p.)
Usunąłem przecinek i wszystko działa :) Zmyliło mnie to że przy próbie ręcznego wpisania tego zapytania w phpmyadmin wszystko przechodziło. Dzięki wielkie za wyjaśnienie i pomoc.

Podobne pytania

+2 głosów
1 odpowiedź 276 wizyt
0 głosów
1 odpowiedź 149 wizyt
pytanie zadane 12 stycznia 2019 w PHP przez _Visni4PL_ Obywatel (1,320 p.)
0 głosów
1 odpowiedź 366 wizyt
pytanie zadane 23 listopada 2017 w PHP przez Zelek Użytkownik (960 p.)

92,452 zapytań

141,262 odpowiedzi

319,085 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...