gpt4 book ai didi

php - 如何使此 MySQL 计数查询更高效?

转载 作者:可可西里 更新时间:2023-11-01 07:33:36 25 4
gpt4 key购买 nike

//get the current member count
$sql = ("SELECT count(member_id) as total_members from exp_members");
$result = mysql_query($sql) or die(mysql_error());
$num_rows = mysql_num_rows($result);
if ($num_rows != 0) {
while($row = mysql_fetch_array($result)) {
$total_members = $row['total_members'];
}
}

//get list of products
$sql = ("SELECT m_field_id, m_field_label from exp_member_fields where m_field_name like 'cf_member_ap_%' order by m_field_id asc");
$result = mysql_query($sql) or die(mysql_error());
$num_rows = mysql_num_rows($result);

if ($num_rows != 0) {

while($row = mysql_fetch_array($result)) {

$m_field_id = $row['m_field_id'];
$m_field_label = $row['m_field_label'];

$sql2 = ("SELECT count(m_field_id_".$m_field_id.") as count from exp_member_data where m_field_id_".$m_field_id." = 'y'");
$result2 = mysql_query($sql2) or die(mysql_error());
$num_rows2 = mysql_num_rows($result2);

if ($num_rows2 != 0) {
while($row2 = mysql_fetch_array($result2)) {
$p = ($row2['count']/$total_members)*100;
$n = $row2['count'];
$out .= '<tr><td>'.$m_field_label.'</td><td>'.number_format($p,1).'%</td><td>'.$n.'</td></tr>';
}
}

}


}

最佳答案

如果您可以用非代码术语描述您要完成的任务,就更容易提供帮助。但问题的一个指标是看到一个查询的行上有一个 php 循环,而另一个查询对每一行执行。

有多种方法可以查询小计。但是如果你能解释一下目标会更容易解释。

关于php - 如何使此 MySQL 计数查询更高效?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6052527/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com