我的数据库“accounts”中有一个sql表,其结构如下所示。
ItemNo CostPrice SellingPrice Discount(10%) Price(INR)
100 $100 $150 $135 Rs.7425
101 $200 $250 $225 Rs.10395
102 $150 $200 $180 Rs.7920
103 $500 $550 $495 Rs.25245
此处每列都依赖于前一列。
SellingPrice = CostPrice + 50
Discount = SellingPrice + (0.1 * SellingPrice)
Price(INR) = SellingPrice * ($_Conversion_rate_to_Rs)
我需要计算SellingPrice并在表格中更新它。 然后我计算折扣并更新表格 然后我计算价格(INR)并更新表格。
我正在尝试以下代码但它似乎无法正常工作。
$i = 0;
foreach($item_no as $item ){
mysql_query("UPDATE accounts SET SellingPrice = CostPrice + 50 WHERE item_no = '$item[$i]'") or die(mysql_error());
++$i;
}
现在,在更新SellingPrice后,我需要计算折扣并更新数据库。
$i = 0;
foreach($item_no as $item ){
mysql_query("UPDATE accounts SET Discount = SellingPrice + (0.1 * SellingPrice) WHERE item_no = '$item[$i]'") or die(mysql_error());
++$i;
}
等等..
我的疑问可能很简单,但我尝试了很多,无法找到正确的解决方案。
我能否知道我的错误和正确的解决方案?
答案 0 :(得分:1)
EDIT!
我编辑多个字段的方式是使用自定义更新功能。该函数采用“field”=>“new value”的关联数组。这是功能:
function update($table,$values,$conditions){
$query = "UPDATE `" . $table . "` SET ";
foreach($values as $key => $value){
if($key == "password")
$query .= "`password` = PASSWORD('" . $mysqli->real_escape_string($value) . "'),";
else if(is_numeric($value))
$query .= "`" . $mysqli->real_escape_string($key) . "` = " . $mysqli->real_escape_string($value) . ",";
else
$query .= "`" . $mysqli->real_escape_string($key) . "` = '" . sanitize($value) . "',";
}
$query = substr($query,0,-1);
if(!is_string($conditions)){
$conditionStr = "";
foreach($conditions as $key => $value){
if($key == "password")
$conditionStr .= "`password` = PASSWORD('" . $mysqli->real_escape_string($value) . "') AND ";
else if(is_numeric($value))
$conditionStr .= "`" . $mysqli->real_escape_string($key) . "` = " . $mysqli->real_escape_string($value) . " AND ";
else
$conditionStr .= "`" . $mysqli->real_escape_string($key) . "` = '" . sanitize($value) . "' AND ";
}
$conditionStr .= substr($conditionStr,0,-4);
$conditions = $conditionStr;
}
$query .= " WHERE " . $conditions . " ;";
$mysqli->query($query);
}
你这样使用它: 更新( “theTable” 阵列( “用户名”=> “中whateverTheNewNameIs”),阵列( “用户ID”=> 55));
更新userID = 55并使用户名成为新用户名。您可以展开第二个数组来更新更多内容。
我认为您的更新和where where子句中存在问题
我会为您的新成本价格制作一个变量,
$newSellingPrice = $item[$i]['sellingPrice'] + 50;
在您的更新中,您可以使用$ newSellingPrice
然后在你的位置,你有一个拼写错误,你没有使用$来获取项目数组。
如果您使用方括号表示法
,则需要保留查询字符串"... WHERE item_no = " . $item[$i] . " ;";
答案 1 :(得分:1)
要回答您的问题,如果您要更新表格中的所有字段,则无需添加WHERE
条件,您只需使用:
UPDATE accounts SET SellingPrice = CostPrice + 50
并且只运行一个查询而不是每个项目一个查询。
然而,依赖于其他列的所有列实际上不需要是单独的列,只需2列的表就可以了得更好,并根据需要计算价格他们。现在您有很多重复的信息,因为成本价格和乘数是您真正需要存储的唯一值。