免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3548 | 回复: 16
打印 上一主题 下一主题

【已解决】一道面试题,求正确解答 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-09-18 10:26 |只看该作者 |倒序浏览
本帖最后由 cenalulu 于 2012-09-28 15:38 编辑

小弟最近浏览了一些PHP_Mysql的面试题,有这样一道题:
一个表中的Id有多个记录,把所有这个id的记录查出来,并显示共有多少条记录数
,总感觉给出的答案有问题,求高手解答

论坛徽章:
0
2 [报告]
发表于 2012-09-18 10:59 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
3 [报告]
发表于 2012-09-18 11:03 |只看该作者
谢谢,
回复 2# kerlion
能否给出语句

   

论坛徽章:
0
4 [报告]
发表于 2012-09-18 11:22 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
5 [报告]
发表于 2012-09-18 11:37 |只看该作者
把所有这个id的记录查出来

这个意思应该是同一个id吧

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
6 [报告]
发表于 2012-09-18 14:54 |只看该作者
我猜想,他想考察的是这个?

$result = mysql_query("SELECT * FROM table1 where id = xxx", $link);
$num_rows = mysql_num_rows($result);

论坛徽章:
8
戌狗
日期:2014-09-26 16:39:44水瓶座
日期:2014-10-10 02:06:57金牛座
日期:2014-10-11 23:04:042015亚冠之首尔
日期:2015-06-23 15:37:0015-16赛季CBA联赛之天津
日期:2016-01-22 18:58:2915-16赛季CBA联赛之佛山
日期:2016-05-31 19:18:0815-16赛季CBA联赛之同曦
日期:2016-08-10 16:26:3315-16赛季CBA联赛之辽宁
日期:2018-01-10 11:47:40
7 [报告]
发表于 2012-09-18 22:38 |只看该作者
这种问题有点让人摸不着头脑

论坛徽章:
0
8 [报告]
发表于 2012-09-19 09:43 |只看该作者
自己写了一个语句
select * from table as A left join ( select B.id,count(*) as num from table as B where B.id=XXX group by B.id ) as C on A.id=C.id where A.id=XXX
不知道对不对,总感觉这样写很别扭

论坛徽章:
8
CU大牛徽章
日期:2013-09-18 15:20:48CU大牛徽章
日期:2013-09-18 15:20:58CU大牛徽章
日期:2013-09-18 15:21:06CU大牛徽章
日期:2013-09-18 15:21:12CU大牛徽章
日期:2013-09-18 15:21:17天秤座
日期:2013-10-30 14:01:03摩羯座
日期:2013-11-29 18:02:31luobin
日期:2016-06-17 17:46:36
9 [报告]
发表于 2012-09-19 17:10 |只看该作者
@cenalulu
@chunhaicao
我感觉这种方法欠佳,会把记录全部拿到PHP这边来,如果只看记录数的话还是group by比较好。
mysql> select * from t;
+------+-------+
| id   | name  |
+------+-------+
|    1 | andy  |
|    1 | mandy |
|    2 | boyod |
+------+-------+

<?php
                $mysqli= new mysqli("localhost","root",'',"test",3306);
                if(mysqli_connect_errno()){
                        echo "error" . mysqli_connect_error();
                        exit;
                }
                $sql="select id,count(*) as coun from t where id=1 group by id";

                $result=$mysqli->query($sql);
                $rows=$result->num_rows;
                $cols=$result->field_count;
                $row=$result->fetch_assoc();
                echo $row['coun'] . "\n";
                $mysqli->close();

?>

论坛徽章:
0
10 [报告]
发表于 2012-09-20 08:29 |只看该作者
回复 9# chinafenghao
但是这样又不能
把所有这个id的记录查出来



   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP