SQL如何按年份月份统计?

SQL如何按年份月份统计?,第1张

select left(convert(varchar(10),[datetime],120),7) as 月份,sum(Amount) as 总数
from 表
where [datetime]<='你输入的时间条件'
group by left(convert(varchar(10),[datetime],120),7)
根据你的数据结果格式重新修改了下:
select cast(datepart(year,[datetime]) as varchar)+'年'+cast(datepart(month,[datetime]) as varchar)+'月' as 月份,sum(Amount) as 总数
from 表
where [datetime]<='你输入的时间条件' and datepart(year,[datetime])=left('你输入的时间条件',4)
group by cast(datepart(year,[datetime]) as varchar)+'年'+cast(datepart(month,[datetime]) as varchar)+'月'

用select sum(列名),sum(列名),sum(列名)…… from 表 where 条件。

假如你的数据列名为:a,b,c,d,e,f,g。那么你横向SQLselecta,b,c,d,e,f,g,a+b+c+d+e+f+g from表名。

那么你纵向汇总的SQL语句是:selesum(a),sum(b),sum(c),sum(d),sum(e),sum(f),sum(g) from 表名。

求所有数据总和的selectsum(a)+sum(b)+sum(c)+sum(d)+sum(e)+sum(f)+sum(g) from 表名。

用select sum(列名),sum(列名),sum(列名)…… from 表 where 条件。

SQL(英文全称:Structured Query Language),即结构化查询语言。SQL是专为数据库而建立的 *** 作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。

SQL功能强大、简单易学、使用方便,已经成为了数据库 *** 作的基础,并且现在几乎所有的数据库均支持SQL。

SQL数据库的数据体系结构基本上是三级结构,但使用术语与传统关系模型术语不同。在SQL中,关系模式(模式)称为“基本表”(basetable);存储模式(内模式)称为“存储文件”(storedfile);子模式(外模式)称为“视图”(view);元组称为“行”(row);属性称为“列”(column)。名称对称如^00100009a^。

数据更新包括数据插入、删除和修改 *** 作。它们分别由INSERT语句,DELETE语句及UPDATE语句完成。

这些 *** 作都可在任何基本表上进行,但在视图上有所限制。其中,当视图是由单个基本表导出时,可进行插入和修改 *** 作,但不能进行删除 *** 作;当视图是从多个基本表中导出时,上述三种 *** 作都不能进行。

数据插入将数据插入SQL的基本表有两种方式:一种是单元组的插入,另一种是多元组的入。单元组的插入:向基本表score中插入一个成绩元组(100002,c02,95),可使用以下语句:INSERTINTOscore(st_no,su_no。

具体的语句跟数据结构和统计要求有关,请参考下列SQL语句

假设有数据表

产量1(id,日期产量

产量2(id,日期,产量)

汇总出两张表2017年每月的总产量

select month(t日期) as 月份,sum(t产量) as 月产量 
from (select 日期,产量 from 产量1 where 日期 
between '2017-01-01' and '2017-12-31' union all 
select 日期,产量 from 产量2 where 日期 
between '2017-01-01' and '2017-12-31' ) t 
group by month(t日期);

SQLSERVER 最原始的SQL写法

CREATE TABLE FenShu

(

name    nvarchar(500),

cdate   date,

je money

)

INSERT INTO FenShu VALUES('语文','2011-5-10',200)

INSERT INTO FenShu VALUES('数学','2011-5-20',600)

INSERT INTO FenShu VALUES('英语','2011-6-10',100)

SELECT name,cdate,je

FROM (

SELECT name,cdate,je,0 AS S1,cdate AS S2

FROM FenShu

UNION ALL

SELECT CAST(cdate AS CHAR(7)),'',SUM(je),1 AS S1,MAX(cdate) AS S2

FROM FenShu

GROUP BY CAST(cdate AS CHAR(7))

)AS T


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/13386323.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-07-26
下一篇 2023-07-26

发表评论

登录后才能评论

评论列表(0条)

保存