2014-04-10 76 views
0

我試圖做一個更新查詢,但我不知道該怎麼做。這是我認爲可能會發揮作用的東西,但事實並非如此。我只需要SQL查詢的幫助。更新多個MySQL列

<?php 
session_start(); 
include_once ('../includes/connection.php'); 
include_once ('../includes/article.php'); 
$artikel = new Artikel; 
if (isset($_SESSION['logged_in'])) { 
    if (isset($_GET['id'])) { 
     $titel = $_POST['titel']; 
     $indhold = $_POST['indhold']; 
     $id = $_GET['id']; 
     $query = $pdo->prepare('UPDATE artikler SET artikel_titel = "?", artikel_indhold = "?", sidst_opdateret = "?" WHERE artikel_id = ?'); 
     $query->bindValue(1, $titel); 
     $query->bindValue(2, $indhold); 
     $query->bindValue(3, time()); 
     $query->bindValue(4, $id); 
     $query->execute(); 
     header('location: index.php'); 
    } 
    $artikler = $artikel->fetch_all(); 
    if (empty($titel) or empty($indhold)) { 
     $error = 'Alle felter skal udfyldes'; 
    } else { 
     $query = $pdo->prepare('INSERT INTO artikler (artikel_titel, artikel_indhold, sidst_opdateret) VALUES (?, ?, ?)'); 
     $query->bindValue(1, $titel); 
     $query->bindValue(2, $indhold); 
     $query->bindValue(3, time()); 
     $query->execute(); 
     header('location: index.php'); 
    } 
?> 
<html> 
<head> 
<meta charset="UTF-8"> 
    <title>Ændre side</title> 
    <link rel="stylesheet" href="../assets/style.css"> 
    <link rel="shortcut icon" href="/billeder/book.png"> 
</head> 
<body> 
<div class="container"> 

    <h4>Ændre side</h4> 
    <br> 
    <form action="edit.php" method="get"> 
    <select name="id"> 
    <?php foreach($artikler as $artikel) { ?> 
    <option value="<?php echo $artikel['artikel_id']; ?>"> 
    <?php echo $artikel['artikel_titel']; ?> 
    </option> 
    <?php } ?> 
    </select> 
    <br> 
    <input type="text" name="titel" placeholder="Ny Titel"> 
    <br> 
     <textarea name="indhold" cols="50" rows="15" placeholder="Indhold"><?php echo $artikel['artikel_indhold']; ?></textarea> 
<br> 
<input type="submit" value="Ændre"> 
    </form> 
    <a href="index.php" id="logo">&larr;Tilbage</a> 
</div> 
</body> 
</html> 
<?php 
} else { 
    header('location: index.php'); 
} 
?> 

回答

1

您準備的陳述不正確。你不會引用佔位符。例如

INSERT INTO foo (bar) VALUES ('?') 
           ^-^--- incorrect 

你做

INSERT INTO foo (bar) VALUES (?) 

代替。數據庫引擎將爲您處理所有報價。

+0

+1'^ - ^' – Dan

+0

難道是bindvalues? – JelloDude

0

Tr的去除'"?各地:爲笑臉貓臉

$query = $pdo->prepare('UPDATE artikler SET artikel_titel = ?, artikel_indhold = ?, sidst_opdateret = ? WHERE artikel_id = ?'); 
+0

沒有工作:( – JelloDude

+0

但謝謝你的幫助:) – JelloDude

+0

難道它是綁定值 – JelloDude