基本上我正在为我的论坛用户建立一个汽车奖励系统.它的作用是检查它们是否符合该奖项IE帖子,因果报应等标准....允许成员自主的问题,如果他们符合此条件..
我面临的一个问题是我想查询MySQL数据库一次并对每个奖项进行多次检查,看看他们是否已经拥有它......如果不允许他们通过点击按钮自行发放奖励.
这是我到目前为止所拥有的
//Query Member Awards DB to check if we already have this Award
$query2 = $smcFunc['db_query']('', '
SELECT id_award, id_member
FROM {db_prefix}awards_members
WHERE id_member = {int:id_prof}',
array(
'id_prof' => $user_info['id'],
)
);
$info2 = $smcFunc['db_fetch_assoc']($query2);
echo $info2['id_award'];
if ($info2['id_award'] == '27')
echo 'exists';
Run Code Online (Sandbox Code Playgroud)
我的桌子看起来像这样
uniq_id id_award id_member date_received favorite
44 29 1 2011-11-02 1
31 21 1 2011-11-02 0
41 32 1 2011-11-02 0
43 27 1 2011-11-02 0
34 18 1 2011-11-02 0
35 38 1 2011-11-02 1
39 31 1 2011-11-02 0
40 30 1 2011-11-02 1
Run Code Online (Sandbox Code Playgroud)
现在基本上下面我会有一堆奖励所有不同的ID我希望能够说如果存在不显示按钮..现在如果只有一个奖项可以检查但我需要检查一些奖项.
我不想使用where子句进行多次查询,以查看该成员是否已获得此奖励.
有没有更简单的方法这样做,所以我只需要一个查询,并可以检查多个奖项..
if ($info2['id_award'] == '1')
echo 'exists';
if ($info2['id_award'] == '2')
echo 'exists';
Run Code Online (Sandbox Code Playgroud)
等等
我对这个最好的方式感到很困惑.任何帮助都会很棒.
编辑:
是的基本上它看起来像这样..我将使用ajax提交数据..
if ($info2['id_award'] != '27') && ($info['karma_good'] >= '100') {
echo '
<form id="karma_god" method="post">
<input type="hidden" id="recipient_to" name="recipient_to" value="' . $info['id_member'] . '" size="32" />
<input type="hidden" id="award" name="award" value="28" size="32" />
<input type="hidden" id="year" name="year" value="' . date('Y') . '" size="32" />
<input type="hidden" id="month" name="month" value="' . date('n') . '" size="32" />
<input type="hidden" id="day" name="day" value="' . date('d') . '" size="32" />
<span>You have above 100 Karma! A New Award Awaits. </span><button class="button"> <img src="http://www.uniquez-home.com/awards/28.gif" alt="" style="vertical-align:bottom;"> Karma God </button>
</form>';
Run Code Online (Sandbox Code Playgroud)
显然,在这一个下面还有一些奖项2 ..
你可以这样做:
Select * FROM awards_member WHERE id_award in (1,2,3,4,5) AND id_member = 5
Run Code Online (Sandbox Code Playgroud)
只需添加您需要检查的额外奖励ID
根据查询结果,您可以遍历每个结果并检查尚未给出哪个奖励ID,并在需要时显示该按钮.
| 归档时间: |
|
| 查看次数: |
4142 次 |
| 最近记录: |