gpt4 book ai didi

php - 选择阻止 user1 访问 user2(反之亦然)

转载 作者:可可西里 更新时间:2023-11-01 07:47:14 25 4
gpt4 key购买 nike

我偶然发现了我的用户对用户阻止功能的问题。

我不知道如何编写 SELECT 以获得正确的结果。当 User1 阻止 user2 时,两个用户都看不到彼此的个人资料,但当我登录时,我可以看到自己的帐户。我正在使用开关来执行此操作。

我的BLOCK 表由IDUSER1_IDUSER2_IDSTATUS 组成. 0 为“可见”,1 为“已阻止”。

函数.用户

public function check_block($user1_id,$user2_id){ 
$check_sql= "SELECT ......";
$check_query = mysql_query($check_sql)or die(mysql_error());
$check_num = mysql_num_rows($check_query);
if($check_num>0){
$block = mysql_fetch_array($check_query);
return $block['status'];
}else{
return $check_num;
}
}

切换

<? 
$user1_id=$_SESSION['id'];
$user2_id=$data['id'];
$userblock = function_user_core::check_block($user1_id,$user2_id);
switch($userblock){
case 1:
echo'You Are Blocked From Viewing This Users Profile';
break;
}
?>

用户个人资料中的字段被阻止

<? if($userblock==1) { ?> 
THIS USER HAS BLOCKED YOU FROM THEIR ACCOUNT
<? } ?>

最佳答案

您似乎在要求示例查询。

看起来您需要一个查询来测试 block 表中是否存在一行,其中 status 设置为“blocked”(1)给定的一对用户。从您问题的措辞来看, user_id 值的顺序似乎无关紧要。 “foo”是否阻止了“bar”或“bar”是否阻止了“foo”,或两者都没有关系(对于此查询)。看起来您的代码在所有这些情况下都将执行完全相同的路径。 (如果我正确理解你的问题。)

这个查询应该得到:

SELECT b.status
FROM block b
WHERE ( b.status = 1 AND b.user1_id = 'foo' AND b.user2_id = 'bar' )
OR ( b.status = 1 AND b.user1_id = 'bar' AND b.user2_id = 'foo' )
LIMIT 1

注意:此查询不考虑用户已阻止自己的极端情况。请参阅下面的查询,也可以处理该条件。

我在我的示例查询中使用了文字“foo”和“bar”,您当然会在 SQL 文本中替换您的(正确转义的)变量。

对于这个检查查询,如果它找到指定给定的一对用户被“阻止”的行,它只需要返回一行。否则,查询不需要返回任何行。使用此查询,您的代码实际上可以更简单一些。使用此查询,您可以简单地从 mysql_num_rows 返回值。

也就是说,你可以替换这个 block :

$check_num = mysql_num_rows($check_query); 
if($check_num>0){
$block = mysql_fetch_array($check_query);
return $block['status'];
}else{
return $check_num;
}

有了这个:

$check_num = mysql_num_rows($check_query); 
return $check_num;

上面的查询没有考虑(不寻常?)极端情况,用户已将自己屏蔽。

如果表格包含这样一行:

('foo','foo',1)

并且您将 'foo' 和 'foo' 的值作为 user_1 和 user_2 传递,上面的查询将返回一行。但是您指定用户应该始终能够查看自己的个人资料。

因此,如果您想忽略任何指定用户在其个人资料中“阻止”自己的条件的行,您可以在查询中添加另一个谓词,以简单地忽略 user_id 值匹配的任何行:

SELECT 1 AS `status`
FROM block b
WHERE b.user1_id <> b.user2_id
AND b.status = 1
AND ( ( b.user1_id = 'foo' AND b.user2_id = 'bar' )
OR ( b.user2_id = 'foo' AND b.user1_id = 'bar' )
)
LIMIT 1

另请注意,如果表中存在冲突行,即一个表示用户对“已被阻止”的原始行和另一行表示该对未被阻止,则“已阻止”状态将优先。

请注意,我们甚至不需要返回 status 列,我们可以返回一个文字值(使用适当的别名来提供您的代码期望的结果集元数据。)

看起来您的代码没有任何问题,但我可能会以不同的方式编写代码。重要的是它易于理解并且有效。


更新:

抱歉,它不适合您。这是我提供的查询的 SQL Fiddle 演示。
http://sqlfiddle.com/#!2/21120/2

很可能是我误解了您试图通过查询完成的目标。我的查询实现的是,如果

  • 'foo' block 'bar' 或
  • 'bar' block 'foo' 或
  • 都互相挡住

然后当传入 ('foo','bar')('bar','foo') 的参数时(以任意顺序),查询返回状态为 1 的行。

否则,也就是说,如果两个用户都没有“阻止”另一个用户,则查询不会返回任何行。

在查询中重要的是,两个提供的“user_id”参数中的每一个都在正确的位置提供两次。 (可以重写查询,以便每个参数只需要提供一次,但该查询(对我而言)并不那么容易理解。)

关于php - 选择阻止 user1 访问 user2(反之亦然),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11530256/

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