Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Zapytanie aktualizujące Mysql z przygotowaną instrukcją daje błąd

W komentarzach zostało powiedziane, że przegapiłeś symbole zastępcze.

Więc zmień:

$sql = 
    "UPDATE blog_posts 
        SET post_title='$post_title', 
        content='$content', 
        author_name='$author_name', 
        category='$category', 
        post_date='$post_date',
        image='$image_name'
        WHERE post_id='$id'";

do:

$sql = 
    "UPDATE blog_posts 
        SET post_title=?, 
        content=?, 
        author_name=?, 
        category=?, 
        post_date=?, 
        image=? 
        WHERE post_id=?";

To takie proste.

Instrukcja zawiera prawidłową składnię:

Nie zapomnij przekazywać argumentów we właściwej kolejności . Powinny być przekazywane w tej samej kolejności, w jakiej zostały użyte w zapytaniu (zamieniłeś obraz z datą publikacji), więc powinno być:

$stmt->bind_param("ssssisi", $post_title, $content, $author_name, $category, $post_date, $image_name, $id);



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Sprawdź język napisów na podstawie glifów w PHP

  2. Obliczenie rozmiaru bazy danych?

  3. Zapytanie SQL do policzenia w grupie według określonego warunku

  4. Jak korzystać z wielu baz danych dla jednej aplikacji rails 3.1 w Heroku?

  5. Poprawki wydajności InnoDB