我偶然发现了我的用户对用户阻止功能的问题。
我不知道如何编写 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','bar') 或 ('bar','foo') 的参数时(以任意顺序),查询返回状态为 1 的行。
否则,也就是说,如果两个用户都没有“阻止”另一个用户,则查询不会返回任何行。
在查询中重要的是,两个提供的“user_id”参数中的每一个都在正确的位置提供两次。 (可以重写查询,以便每个参数只需要提供一次,但该查询(对我而言)并不那么容易理解。)
关于php - 选择阻止 user1 访问 user2(反之亦然),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11530256/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
我怎样才能完成http://php.net/manual/en/function.call-user-func-array.php在ruby中?所以我可以这样做:classAppdeffoo(a,b)putsa+benddefbarargs=[1,2]App.send(:foo,args)#doesn'tworkApp.send(:foo,args[0],args[1])#doeswork,butdoesnotscaleendend 最佳答案 尝试分解数组App.send(:foo,*args)
我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah
我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以
状态:我正在构建一个应用程序,其中需要一个可供用户选择颜色的字段,该字段将包含RGB颜色代码字符串。我已经测试了一个看起来很漂亮但效果不佳的。它是“挑剔的颜色”,并托管在此存储库中:https://github.com/Astorsoft/picky-color.在这里我打开一个关于它的一些问题的问题。问题:请建议我在Rails3应用程序中使用一些颜色选择器。 最佳答案 也许页面上的列表jQueryUIDevelopment:ColorPicker为您提供开箱即用的产品。原因是jQuery现在包含在Rails3应用程序中,因此使用基
我想从then子句中访问case语句表达式,即food="cheese"casefoodwhen"dip"then"carrotsticks"when"cheese"then"#{expr}crackers"else"mayo"end在这种情况下,expr是食物的当前值(value)。在这种情况下,我知道,我可以简单地访问变量food,但是在某些情况下,该值可能无法再访问(array.shift等)。除了将expr移出到局部变量然后访问它之外,是否有直接访问caseexpr值的方法?罗亚附注我知道这个具体示例很简单,只是一个示例场景。 最佳答案
我理解(我认为)Ruby中类变量和类的实例变量之间的区别。我想知道如何从该类外部访问该类的实例变量。从内部(即在类方法中而不是实例方法中),它可以直接访问,但是从外部,有没有办法做MyClass.class.[@$#]variablename?我没有任何具体原因要这样做,只是学习Ruby并想知道是否可行。 最佳答案 classMyClass@my_class_instance_var="foo"class上述yield:>>foo我相信Arkku演示了如何从类外部访问类变量(@@),而不是类实例变量(@)。我从这篇文章中提取了上述内
我试图在我的网站上实现使用Facebook登录功能,但在尝试从Facebook取回访问token时遇到障碍。这是我的代码:ifparams[:error_reason]=="user_denied"thenflash[:error]="TologinwithFacebook,youmustclick'Allow'toletthesiteaccessyourinformation"redirect_to:loginelsifparams[:code]thentoken_uri=URI.parse("https://graph.facebook.com/oauth/access_token
我完全不是程序员,正在学习使用Ruby和Rails框架进行编程。我目前正在使用Ruby1.8.7和Rails3.0.3,但我想知道我是否应该升级到Ruby1.9,因为我真的没有任何升级的“遗留”成本。缺点是什么?我是否会遇到与普通gem的兼容性问题,或者甚至其他我不太了解甚至无法预料的问题? 最佳答案 你应该升级。不要坚持从1.8.7开始。如果您发现不支持1.9.2的gem,请避免使用它们(因为它们很可能不被维护)。如果您对gem是否兼容1.9.2有任何疑问,您可以在以下位置查看:http://www.railsplugins.or