gpt4 book ai didi

php - MySQL复杂查询。基于另一个表动态更新行

转载 作者:搜寻专家 更新时间:2023-10-31 22:03:54 25 4
gpt4 key购买 nike

enter image description here

上面是我画的方案。有一个理想情况,当 content.user被分组。但通常他们不分组。我在这个方案中的意思是:

  1. 第一步,我选择 users.monetos在哪里users.id = content.user

  2. 在第二步,我递减 users.monetos每个content.cpc值 (2.1 , 2.2)

模拟时: 选择 content.user (9)

选择users.monetos在哪里users.id=content.users (15)

所以我们有 15 个值 users.monetos对于 users.id=9 , 现在我们回到内容表和:

  1. 将 15 的值减 8 ( content.cpc ) (15-8=7> 0 -> 转到步骤 2)
  2. 将 7(上一步的结果)减 10(content.cpc)(7-10=-3 <0 -> 更新content set active='0' where content.id=(获得否定结果时的当前id))

对于每个 content.user 都是这样

更扩展 - 我想选择 contet.*具有 content.active 的行= 1 (n)。有了这些数据,SELECT users.monetos在哪里users.id = content.user从以前的查询。现在,通过最大 (n) 步,我递减 users.monetoscontent.cpc 值计算的值当**users.monetos=0 或小于 0 时,我想更新 content和 SET active='0'**

言下之意,我想分享每个content 条目的users.monetos 金额(每个content.cpc)。并且没有更多的 users.monetos 成为当前的 content输入无效。对每个 content.user 都这样做我现在所做的如下所示。我现在看起来很糟糕,但我已经不知道该怎么办了。

$query = "select content.id, content.cpc, conent.user, content.active from content a
join users b on a.user=b.id
group by b.id where a.active='1'";

/** cycle each user **/
foreach($rows = $connector->fetchArray($query) as $row ) {
$monetos = $row['monetos'];
$query = "select id, cpc from content where user={$row['id']}";
/** cycle each users content **/
foreach($contents = $connector->fetchArray($query) as $content) {
echo $monetos;
$monetos -= $content['cpc'];
if($monetos <= 0) {
$disable[] = $content['id'];
}
}
if( isset($disable) ) {
$connector->query("update content set active='0' where id in(".implode(',',$disable).")");
}
}

最佳答案

你可以试试这段代码:

$query = "select * from users";
foreach($rows = $connector->fetchArray($query) as $row ) {
$a='';
$query = "select * from content where user='{$row[id]}' and active='1' ";
foreach($contents = $connector->fetchArray($query) as $content ) {
$a++;
$a_min=$a-1;
$test[$a]=$row[monetos]-$content[cpc];
if($a==2){
if($test[$a_min] > 0){
$test2=$test[$a_min]-$content[cpc];
if($test2 < 0){
$connector->query("update content set active='0' where id='$content[id]'");
}
}
}
}
}

关于php - MySQL复杂查询。基于另一个表动态更新行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22611315/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com