sql 常用的查询套路

1. 写一个sql:,查询商城每天的用户数及每天累计用户数

date        user_count  total_count
2016-12-01    1            1
2016-12-02    2            3
2016-12-03    2            5
2016-12-04    6            11

(user_count 每天的访问数 total_count 总访问数)

方法一:(是错误的)

select 
A.date,A.user_conut,(A.user_conut+B.user_conut) total_count
from 
(select date,count(1) user_count from
 user  group by date
) A
join (select date,count(1) user_count from
 user  group by date
) B
on A.date-1=B.date

方法二:

select date, COUNT(test)  user_count,total_count=(    
        select COUNT(test)     
        from     
            test1 i    
        where     
             i.date<=o.date    
        )     from test1 o group by date

方法三:

WITH cte AS(
SELECT a.date,COUNT(1) AS user_count FROM dbo.test007 AS a GROUP BY a.date
)
SELECT a.date,a.user_count,(SELECT SUM(user_count) FROM cte AS b where b.date<=a.date) AS total_count FROM cte AS a

---------------------------------------------------------------

2.

一条sql掏出每个分类的前两条记录

一条sql取出每个分类的前两条记录

  写道

  --> 生成测试数据: #T 
IF OBJECT_ID(‘tempdb.dbo.#T‘) IS NOT NULL DROP TABLE #T 
CREATE TABLE #T (ID VARCHAR(3),GID INT,Author VARCHAR(29),Title VARCHAR(39),Date DATETIME) 
INSERT INTO #T 
SELECT ‘001‘,1,‘邹建‘,‘深入浅出SQLServer2005开发管理与应用实例‘,‘2008-05-10‘ UNION ALL 
SELECT ‘002‘,1,‘胡百敬‘,‘SQLServer2005性能调校‘,‘2008-03-22‘ UNION ALL 
SELECT ‘003‘,1,‘格罗夫Groff.J.R.‘,‘SQL完全手册‘,‘2009-07-01‘ UNION ALL 
SELECT ‘004‘,1,‘KalenDelaney‘,‘SQLServer2005技术内幕存储引擎‘,‘2008-08-01‘ UNION ALL 
SELECT ‘005‘,2,‘Alex.Kriegel.Boris.M.Trukhnov‘,‘SQL宝典‘,‘2007-10-05‘ UNION ALL 
SELECT ‘006‘,2,‘飞思科技产品研发中心‘,‘SQLServer2000高级管理与开发‘,‘2007-09-10‘ UNION ALL 
SELECT ‘007‘,2,‘胡百敬‘,‘SQLServer2005数据库开发详解‘,‘2008-06-15‘ UNION ALL 
SELECT ‘008‘,3,‘陈浩奎‘,‘SQLServer2000存储过程与XML编程‘,‘2005-09-01‘ UNION ALL 
SELECT ‘009‘,3,‘赵松涛‘,‘SQLServer2005系统管理实录‘,‘2008-10-01‘ UNION ALL 
SELECT ‘010‘,3,‘黄占涛‘,‘SQL技术手册‘,‘2006-01-01‘

--SQL查询如下:

--按GID分组,查每个分组中Date最新的前2条记录

--1.字段ID唯一时: 
SELECT * FROM #T AS T WHERE ID IN(SELECT TOP 2 ID FROM #T WHERE GID=T.GID ORDER BY Date DESC)

--2.如果ID不唯一时: 
SELECT * FROM #T AS T WHERE 2>(SELECT COUNT(*) FROM #T WHERE GID=T.GID AND Date>T.Date)

--SQL Server 2005 使用新方法

--3.使用ROW_NUMBER()进行排位分组 
SELECT ID,GID,Author,Title,Date 
FROM 

SELECT rid=ROW_NUMBER() OVER(PARTITION BY GID ORDER BY Date DESC),* 
FROM #T 
) AS T 
WHERE rid<=2

--4.使用APPLY 
SELECT DISTINCT b.* 
FROM #T AS a 
CROSS APPLY 

SELECT TOP(2) * FROM #T WHERE a.GID=GID ORDER BY Date DESC 
) AS b

--结果 
/*

ID GID Author Title Date 
---- ----------- ----------------------------- --------------------------------------- ----------------------- 
003 1 格罗夫Groff.J.R. SQL完全手册 2009-07-01 00:00:00.000 
004 1 KalenDelaney SQLServer2005技术内幕存储引擎 2008-08-01 00:00:00.000 
005 2 Alex.Kriegel.Boris.M.Trukhnov SQL宝典 2007-10-05 00:00:00.000 
007 2 胡百敬 SQLServer2005数据库开发详解 2008-06-15 00:00:00.000 
009 3 赵松涛 SQLServer2005系统管理实录 2008-10-01 00:00:00.000 
010 3 黄占涛 SQL技术手册 2006-01-01 00:00:00.000

(6 行受影响)

  以上内容引自互联网,

  下面简要说明下在什么情况下会遇到此种情景,

  比如有这样一种需求:

  某一父类有很多的子类,每一子类又对应多条内容,此时我们需要获取包含该父类下所有子类的内容,且规定每个子类限取两条,则可以使用以上方法,具体使用情况可根据以上方式区别对待。

-------------------

select *
from
(select *,row_number() over(partition by classid order by classid) as rownum  
--上面利用row_number()先按classid分类,然后给每类内分别编号1、2、3...
from tb) as tb1
where rownum<4

--------------------------------

要 id为188的前三条和id189的前三条 下面还有 每种都有前三条 要 oracle的代码 谢谢

最佳答案:

select a.* from

(select row_number()over(partition by id order by 排序字段) as num,*

from [table] )a where num<=3

[SQL]select a.* from(select row_number()over(partition by MENU_PARENTID order by MENU_PARENTID) as num,*from DL_MENU )a where num<=3[Err] ORA-00936: missing expression

追答

select a.* from(select row_number()over(partition by menu_parentid order by menu_parentid) as num,t.*from DL_MENU t)a where num<=3

比如有分类表category。表中有A,B,C,D四个分类

商品表product中有一人categoryId与category关联。

请问:如何人product表中获取每个分类的第一条数据呢?

CREATE table Cate
(CateID int,
CateName Nvarchar(20));

CREATE table Product
(ProductID int,
CateID int,
ProductName Nvarchar(20));

INSERT Cate
values
(1,‘DemoA‘),
(2,‘DemoB‘),
(3,‘DemoC‘),
(4,‘DemoD‘)

INSERT PRODUCT
values
(1,1,‘PA‘),
(2,3,‘PB‘),
(3,2,‘PC‘),
(4,2,‘PD‘),
(5,4,‘PE‘),
(6,3,‘PF‘),
(7,1,‘PG‘),
(8,4,‘PH‘)

SELECT * FROM product;
/*
ProductID    CateID    ProductName
1    1    PA
2    3    PB
3    2    PC
4    2    PD
5    4    PE
6    3    PF
7    1    PG
8    4    PH
*/
--方法一:
Select t.CateID,t.ProductID,t.ProductName
From
(Select CateID,ProductID,ProductName,
Row_Number() over(Partition By CATEID Order by productid Asc) RowID
From PRODUCT
) t WHERE t.RowID=1

--方法二:
SELECT CateID,ProductID,ProductName  FROM PRODUCT T
WHERE productID in (
    SELECT top 1 productID  FROM PRODUCT
    WHERE cateid=T.cateid order by cateID asc )

/*

CateID    ProductID    ProductName
1    1    PA
2    3    PC
3    2    PB
4    5    PE
*/

时间: 2024-10-13 03:01:36

sql 常用的查询套路的相关文章

数据库基本查询语句(SQL常用增删改查语句 简单复习 mark)

SQL常用增删改查语句 1增 1.1[插入单行]insert [into] <表名> (列名) values (列值)例:insert into Strdents (姓名,性别,出生日期) values ('开心朋朋','男','1980/6/15') 1.2[将现有表数据添加到一个已有表]insert into <已有的新表> (列名) select <原表列名> from <原表名>例:insert into tongxunlu ('姓名','地址','

常用数据库查询判断表和字段是否存在的SQL

常用数据库查询判断表和字段是否存在的SQL(如果结果为1表示存在,为0表示不存在) 1.MSSQL Server 表: SELECT COUNT(*) FROM dbo.sysobjects  WHERE name= 'table_name'; 字段: SELECT COUNT(*) FROM syscolumns  WHERE id=object_id('table_name') AND name= 'column_name'; 2.My SQL 表: SELECT COUNT(*) FROM

SQL Server 常用日期查询语句

--本月月初select  dateadd(mm,datediff(mm,0,getdate()),0) --本月月末select  DATEADD(DD,-1,DATEADD(MONTH,1+DATEDIFF(MONTH,0,GETDATE()),0))--设置每周的第一天为星期一SET  DateFirst 1declare @cur_week1 varchar(10)--本周第一天select @cur_week1=DATEADD(DAY,1-DATEPART(WEEKDAY,getdat

Sql Server参数化查询之where in和like实现详解

来自:http://www.cnblogs.com/lzrabbit/archive/2012/04/22/2465313.html#wherein 文章导读 拼SQL实现where in查询 使用CHARINDEX或like实现where in 参数化 使用exec动态执行SQl实现where in 参数化 为每一个参数生成一个参数实现where in 参数化 使用临时表实现where in 参数化 like参数化查询 xml和DataTable传参  身为一名小小的程序猿,在日常开发中不可以

SQL Server之 (二) SQL语句 模糊查询 空值处理 聚合函数

(二) SQL语句  模糊查询  空值处理  聚合函数 自己学习笔记,转载请注明出处,谢谢!---酸菜 SQL :结构化查询语言(Structured Query Language),关系数据库管理系统的标准语言. Sybase与Mircosoft对标准SQL做了扩展:T-SQL (Transact-SQL); 注:①SQL对大小写的敏感取决于排序规则,一般不敏感; ②SQL对单引号的转义,用两个单引号来表示一个单引号; ③SQL执行顺序: 1→2→3→4 select  * ---------

50种方法优化SQL Server数据库查询(转载)

原文地址:http://www.cnblogs.com/zhycyq/articles/2636748.html 查询速度慢的原因很多,常见如下几种: 1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2.I/O吞吐量小,形成了瓶颈效应. 3.没有创建计算列导致查询不优化. 4.内存不足 5.网络速度慢 6.查询出的数据量过大(可以采用多次查询,其他的方法降低数据量) 7.锁或者死锁(这也是查询慢最常见的问题,是程序设计的缺陷) 8.sp_lock,sp_who,活动的用

SQL常用语法大全

一.基础1.说明:创建数据库CREATE DATABASE database-name 2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数据的 deviceUSE masterEXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'--- 开始 备份BACKUP DATABASE pubs TO testBack 4.说明:创建新表create

SQL 常用语句

–-表现最差的前10名使用查询 SELECT TOP 10 ProcedureName = t.text, ExecutionCount = s.execution_count, AvgExecutionTime = isnull ( s.total_elapsed_time / s.execution_count, 0 ), AvgWorkerTime = s.total_worker_time / s.execution_count, TotalWorkerTime = s.total_wo

Mysql数据库理论基础之三 --- 数据类型及SQL结构化查询语句使用

一.简介 由MySQL AB公司开发,是最流行的开放源码SQL数据库管理系统,主要特点: 1.是一种数据库管理系统 2.是一种关联数据库管理系统 3.是一种开放源码软件,且有大量可用的共享MySQL软件 4.MySQL数据库服务器具有快速.可靠和易于使用的特点 5.MySQL服务器工作在客户端/服务器模式下,或嵌入式系统中 InnoDB存储引擎将InnoDB表保存在一个表空间内,该表空间可由数个文件创建.这样,表的大小就能超过单独文件的最大容量.表空间可包括原始磁盘分区,从而使得很大的表成为可能