分类 SQL 下的文章

MYSQL用group by去重后,再用count计算条数

假如表数据是:

name    id
刘德华   1
张学友   2
黎明     3
杨幂     2
赵丽颖   3

现在要查出有相同id的数量,并按id顺序排列,形成如下结果:

id    num
1     1
2     2
3     2

SQL语句:

SELECT id,COUNT(*) as num FROM table WHERE 1=1 GROUP BY id ORDER BY id

阅读剩余部分

无限级结构SQL查询所有上级和所有下级

Id,PId无限级结构,查询某个Id的所有下级或所有上级,使用WITH AS查询:

/*查找Id为1所有的下级*/
WITH T
AS( 
    SELECT Id,PId,Name,0 L FROM User WHERE Id=1
    UNION ALL 
    SELECT U.Id,U.PId,U.Name,L+1   
    FROM User U INNER JOIN T ON U.PId=T.Id  
) 
SELECT * FROM T

/*查找Id为100所有的上级*/
WITH T
AS( 
    SELECT Id,PId,Name,0 L FROM User WHERE Id=100
    UNION ALL 
    SELECT U.Id,U.PId,U.Name,L+1   
    FROM User U INNER JOIN T ON U.Id=T.PId  
) 
SELECT * FROM T

阅读剩余部分

SQL server中多列数据有NULL值时如何汇总

在一个表中,假如有两个数值字段a,b,这两个字段每一行的值要合并成一个字段C,SQL语句写法:a + b AS c

如果字段b那一列有一行的值为NULL,按上面语句写法合并成c后,那一行会显示NULL,此时应该把NULL处理为0,加起来的数据才对头。

SQL server中多列数据有NULL值时如何汇总.png

阅读剩余部分