我偶然发现了我的用户对用户阻止功能的问题。
我不知道如何编写 SELECT
以获得正确的结果。当 User1 阻止 user2 时,两个用户都看不到彼此的个人资料,但当我登录时,我可以看到自己的帐户。我正在使用开关来执行此操作。
我的BLOCK
表由ID
、USER1_ID
、USER2_ID
和STATUS
组成. 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/