データベースに配列を追加したい。 db(例:health
およびmoney
)の値が変更されたかどうかをチェックする関数を設定しました。値がオリジナルと異なる場合は、新しい値を$db
配列に追加します。このように$db['money'] = $money_input + $money_db;
。配列をmysqlデータベースに挿入するPHP
function modify_user_info($conn, $money_input, $health_input){
(...)
if ($result = $conn->query($query)) {
while ($user = $result->fetch_assoc()) {
$money_db = $user["money"];
$health_db = $user["health"];
}
$result->close();
//lag array til db med kolonnene som skal fylles ut som keys i array
if ($user["money"] != $money_input){
$db['money'] = $money_input + $money_db;
//0 - 20
if (!preg_match("/^[[0-9]{0,20}$/i", $db['money'])){
echo "error";
return false;
}
}
if ($user["health"] != $health_input){
$db['health'] = $health_input + $health_db;
//0 - 4
if (!preg_match("/^[[0-9]{0,4}$/i", $db['health'])){
echo "error";
return false;
}
if (($db['health'] < 1) or ($db['health'] > 1000))
{
echo "error";
return false;
}
}
$db
のキーは、データベースの列を表します。今度は、配列$db
のキーを取得し、それらをdbに挿入する関数を作成したいと思います。このようなもの ?
$query = "INSERT INTO `main_log` (`id` , ";
foreach(range(0, x) as $num) {
$query .= array_key.", ";
}
$query = substr($query, 0, -3);
$query .= " VALUES ('', ";
foreach(range(0, x) as $num) {
$query .= array_value.", ";
}
$query = substr($query, 0, -3);
$query .= ")";