亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何在一個 MySQL 數據庫更新中執行多個數學方程式?

如何在一個 MySQL 數據庫更新中執行多個數學方程式?

PHP
慕碼人8056858 2022-12-03 10:40:48
我有一個 MySQL 數據庫行,用于存儲游戲的嘗試次數和平均得分:+-----+----------+-----------+| uid | attempts | avg_score ||  4  |    3     |    15     |+-----+----------+-----------+用戶完成游戲后,我想更新這兩個表以根據新的嘗試計算出新的平均值。我想:乘以(嘗試* avg_score = 45)將trial_score添加到總avg_score(avg_score(45)+ trial_score(5)= 50)除以(avg_score(45)+ trial_score(5)/嘗試=嘗試+ 1)對于 PHP mySQL 語句,這有點讓我頭疼。我將在下面展示我的嘗試。$sql=("UPDATE gamescore SET attempts = attempts + 1,avg_score = ((attempts * avg_score + ?) / (attempts = attempts + 1)) WHERE uid=?");$stmt = $conn->prepare($sql);$stmt->bind_param("ii",$_POST['trial_score'],$_SESSION['uid']);$stmt->execute();失敗..顯然...我需要在這里更正什么?謝謝!
查看完整描述

1 回答

?
一只甜甜圈

TA貢獻1836條經驗 獲得超5個贊

你必須除以(attempts + 1)而不是(attempts = attempts + 1)。

還要設置avg_scorefirst 和 then的值,attempts因為如果先設置attempts,則設置 MySql 值的表達式中的值avg_score將使用修改后的值attempts(您可以在此處找到更多信息):


UPDATE gamescore  

SET avg_score = (attempts * avg_score + ?) / (attempts + 1),

    attempts = attempts + 1 

WHERE uid = ?;


查看完整回答
反對 回復 2022-12-03
  • 1 回答
  • 0 關注
  • 106 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號