我有用逗号分隔的数据库中存储的用户选项,我有用户选择这些选项的完整选项列表。我试图让选项用户选中,然后将它分开,用逗号分隔每个值,然后将其与完整选项进行比较,并使用复选框选中所有选项中的用户选项。并保持其他选项不受限制。但问题是我的结果越来越重复。这是我的代码
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
}
}
}
?>
答案 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,',%');
这将为每个宗教返回一行,使用LEFT JOIN
查看它是否列在用户的宗教列表中。
应该做的是不将逗号分隔值存储在列中,而是将宗教列表分解为单独的表。这将允许数据库对数据进行更高效的查询。上面的查询不使用任何索引进行字符串匹配,如果宗教数量增加,这可能在将来成为一个问题。