在做資料操作的時候,如果遇到一些複選的項目,我們會先建立一個項目的資料表,內容範例如下:
我建立一個 hobby 的資料表
接著用一個關聯的資料表去儲存某個帳號的 hobby 有哪些,我把資料表命名為 user_hobby,範例的內容如下:
從關聯資料表可以知道 1 號使用者的興趣有 2、4、5 三個,那接著如果我們要修改的話,還是會先把 hobby 資料表的內容都撈出來像這樣:
$stmt=$db_host->prepare("SELECT * FROM hobby"); try{ $stmt->execute(); $rows=$stmt->fetchAll(PDO::FETCH_ASSOC); }catch(PDOExecption $e){ echo "讀取資料失敗"; }
再把它顯示出來:
<?php foreach($rows as $value){ ?>
<input type="checkbox" name="hobby[]" value="<?=$value["id"]?>"><label for=""><?=$value["name"]?></label>
<?php } ?>
接著要去從 user_hobby 的資料表撈出這個使用者有哪些嗜好,大概會像這樣寫:
$id=$_GET["id"]; $stmtHobby=$db_host->prepare("SELECT * FROM user_hobby WHERE user_id=?"); $stmtHobby->execute([$id]); $hobbyRows=$stmtHobby->fetchAll(PDO::FETCH_ASSOC);
接著就是把使用者的 hobby 跟所有的 hobby 的 id 做比對,只要他有那個嗜好的 hobby_id,就把 checkbox 勾起來,這邊我們可以用比對資料是否存在陣列的做法,所以我們先把使用者的 hobby 資料整理一下:
$userHobby=array(); foreach($hobbyRows as $value){ array_push($userHobby, $value["hobby_id"]); }
然後在顯示 checkbox 的時候把是否有這個 hobby 的判斷帶進去:
<?php foreach($rows as $value){ ?>
<input type="checkbox" name="hobby[]"
<?php if(in_array($value["id"], $userHobby))echo "checked" ?>
value="<?=$value["id"]?>"><label for=""><?=$value["name"]?></label>
<?php } ?>
這樣就搞定了。