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

标签 php mysql sql profile blocking

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

我不知道如何编写 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/

相关文章:

PHP move_uploaded_file 权限被拒绝(权限设置为 755)

php - 使用数据库或公共(public)变量从大数据中选择

php - jQuery UI 自动完成 - 西类牙字符在本地正确显示但在服务器上不正确

MySQL:奇怪的自动增量

mysql - 如何使用条件对 mysql 数据库进行不同的连接

sql - Elasticsearch 通过两个字段之一进行匹配

php - 文件夹内的文件夹内的 Controller 不起作用(Codeigniter)

mysql - 从本地主机连接到 Docker MySQL 容器?

java - 如何在java中为每个线程分配一定数量的rdms记录进行处理

sql - 我如何在 azure for DTU 上自动运行此脚本