与循环结果进行比较时,mysql结果会重复出现

时间:2013-05-05 07:07:09

标签: php mysql

我有用逗号分隔的数据库中存储的用户选项,我有用户选择这些选项的完整选项列表。我试图让选项用户选中,然后将它分开,用逗号分隔每个值,然后将其与完整选项进行比较,并使用复选框选中所有选项中的用户选项。并保持其他选项不受限制。但问题是我的结果越来越重复。这是我的代码

function 

     get_religion_pref($page,$user_id)

        {
            $getrow=mysql_query("select * from religion");
            while($results=mysql_fetch_array($getrow))
            {
                $main_values=$results['religion'];
                $query=mysql_query("select * from partner_prefrences where uid=$user_id");
                    $row=mysql_fetch_array($query);

                    $string =$row['religion'];
                    $string = preg_replace('/\.$/', '', $string); //Remove dot at end if exists                                                       

                   $array = explode(',', $string); //split string into array seperated by ', '
                  foreach($array as $value) //loop over values
                        {
                        ?>
                        <li>
                            <label class="checkbox">
                            <input type="checkbox" value="<?php echo $main_values; ?>" 
                     <?php if($main_values==$value){?> checked <?php } ?>><?php echo $main_values; ?>

                            </label>
                            </li>
                            <?php
                            }
                            }
                            }
                                    ?>

1 个答案:

答案 0 :(得分:1)

由于您遇到了循环问题,为什么不在MySQL中完成整个操作而不是进行多次查询;

SELECT r.id, r.religion,IFNULL(p.uid,0) selected
FROM religion r
LEFT JOIN partner_preferences p
  ON p.uid=1 
 AND CONCAT(',',p.religion,',') 
   LIKE CONCAT('%,',r.religion,',%');

An SQLfiddle to test with

这将为每个宗教返回一行,使用LEFT JOIN查看它是否列在用户的宗教列表中。

应该做的是不将逗号分隔值存储在列中,而是将宗教列表分解为单独的表。这将允许数据库对数据进行更高效的查询。上面的查询不使用任何索引进行字符串匹配,如果宗教数量增加,这可能在将来成为一个问题。