日期:2014-05-16  浏览次数:20860 次

请教一条查询SQL的写法
SQL code
create table family (
       id int,
       name varchar(10),
       parentId int 
) 

insert into family values(1,"张三",5);
insert into family values(2,"张四",5);   
insert into family values(3,"李三",6);
insert into family values(4,"李四",NULL);
insert into family values(5,"张_父",7);
insert into family values(6,"李_父",8);
insert into family values(7,"张_父_父",NULL);
insert into family values(NULL,NULL,NULL);

--查出如下结构:
--家族 人数
------------
--张   4
--李   2
--李   1

不会写,请教一下大家,谢谢。

------解决方案--------------------
SQL code
select  left(name,1),count(*)
from family
group by left(name,1)

------解决方案--------------------
参考下贴中的方法

http://blog.csdn.net/acmain_chm/article/details/4142971
MySQL中进行树状所有子节点的查询
在Oracle 中我们知道有一个 Hierarchical Queries 通过CONNECT BY 我们可以方便的查了所有当前节点下的所有子节点。但很遗憾,在MySQL的目前版本中还没有对应的功能。 在MySQL中如果是有限的层次,比如我们事先如果可以确定这个树的最大深度是4, 那么所有节点为根的树的深度均不会超过4,则我们可以直接通过left join 来实现。 但很多时候我们...
------解决方案--------------------
MYSQL不支持递归查询,用SP来解决
------解决方案--------------------
mysql是不支持递归查询的。
------解决方案--------------------
探讨

SQL code
select left(name,1),count(*)
from family
group by left(name,1)

------解决方案--------------------
SQL code
select left(name,1),count(*)
from family
group by left(name,1)

可行