我正在尝试从多个mysql数据库中添加项数(我还没有添加到部分),以在我的主页上打印记录总数.
我已经从Google搜索的几个站点中获取了“计数”代码的基础知识,但是有些不正确.如果我在phpMyAdmin中单独运行下面的查询,它可以正常工作(我从1个数据库中获得36个结果),但是当我在php页面中通过以下代码运行该查询时,它仅返回1.
知道我搞砸了吗?谢谢.
$connection="localhost";
$username="myusername";
$password="mypassword";
$database1="mydb1";
$database2="mydb2";
$db1 = mysql_connect($connection,$username,$password) or die(mysql_error());
$sel1 = mysql_select_db($database1, $db1);
$query1 = "SELECT count(postID) FROM my_table";
$result1 = mysql_query($query1, $db1);
$db2 = mysql_connect($connection,$username,$password) or die(mysql_error());
$sel2 = mysql_select_db($database2, $db2);
$query2 = "SELECT count(postID) FROM my_table";
$result2 = mysql_query($query2, $db2) or die(mysql_error());
$total_rows = mysql_num_rows($result2);
print $total_rows;
解决方法:
由于它们位于同一数据库主机(本地主机)上,因此您只需一次查询即可获取它们.此方法使用一个子查询,该子查询将来自每个数据库的查询联合在一起,然后执行聚合SUM()将它们添加在一起.
SELECT SUM(postcounts) AS total
FROM (
SELECT COUNT(postId) AS postcounts FROM mydb1.my_table
UNION ALL
SELECT COUNT(postId) AS postcounts FROM mydb2.my_table
) allposts
mysql_num_rows()返回1的原因是因为每个查询仅返回一行-总计COUNT(postIdD).如果要检索实际计数,则需要获取该行.
假设上面的查询存储在$result中,则需要将别名别名为total:
if ($result) {
$row = mysql_fetch_assoc($result);
echo $row['total'];
}
整个过程看起来像:
$db1 = mysql_connect($connection,$username,$password) or die(mysql_error());
mysql_select_db($database1, $db1);
$query = "
SELECT SUM(postcounts) AS total
FROM (
SELECT COUNT(postId) AS postcounts FROM mydb1.my_table
UNION ALL
SELECT COUNT(postId) AS postcounts FROM mydb2.my_table
) allposts ";
$result = mysql_query($query, $db1);
// Fetch the resultant row
if ($result) {
$row = mysql_fetch_assoc($result);
echo $row['total'];
}
标签:count,mysql,php 来源: https://codeday.me/bug/20191201/2081060.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。