统计问题,先谢谢了!!

koukoujiayi 2009-09-08 05:31:30
有两个表:

T1表
year1 areaID(唯一)
1999 1
1999 2
1999 3
2000 4
2000 5
2001 6

T2表
areaID
1
1
1
2
2
4
4
4
5

想得到:
year1 areaCount yearCount
1999 5 3
2000 4 2
2001 1 1

若T2中没有T1的areaID,则areaCount为1,如T1表中的2001,在T2表中没有!!

先谢谢大家了!!
...全文
222 38 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
38 条回复
切换为时间正序
请发表友善的回复…
发表回复
lsd123 2009-09-08
  • 打赏
  • 举报
回复
.
ws_hgo 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 36 楼 js_szy 的回复:]
引用 34 楼 koukoujiayi 的回复:
8楼的代码@TT用什么代啊!!
抱歉麻烦说一下!!


你只要把8楼的代码应用到你的表上,把对应的表明改下就可以了
[/Quote]
小卒
以后注意看清题目啊
华夏小卒 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 34 楼 koukoujiayi 的回复:]
8楼的代码@TT用什么代啊!!
抱歉麻烦说一下!!
[/Quote]

你只要把8楼的代码应用到你的表上,把对应的表明改下就可以了
ws_hgo 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 34 楼 koukoujiayi 的回复:]
8楼的代码@TT用什么代啊!!
抱歉麻烦说一下!!
[/Quote]
用什么代??
你可以
create table TT
(
...
)
delare @TT table
(
..
)
都可以啊
koukoujiayi 2009-09-08
  • 打赏
  • 举报
回复
8楼的代码@TT用什么代啊!!
抱歉麻烦说一下!!
ws_hgo 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 32 楼 koukoujiayi 的回复:]
引用 26 楼 js_szy 的回复:
我搞晕了,不知道到底是0,还是1了

楼主能说下,为什么2001的areaCount 的是1吗???

如果,你把2001, 6这个算一个得话

那1999,3 为什么不算一条呢,那1999且不是3+2+1=6条了

这是自定的规则,如有则不加1,如无则加1!!

[/Quote]
isnull(areaCount,1)是这个功能的
你看下isnull函数
koukoujiayi 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 26 楼 js_szy 的回复:]
我搞晕了,不知道到底是0,还是1了

楼主能说下,为什么2001的areaCount 的是1吗???

如果,你把2001, 6这个算一个得话

那1999,3 为什么不算一条呢,那1999且不是3+2+1=6条了
[/Quote]
这是自定的规则,如有则不加1,如无则加1!!
ws_hgo 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 30 楼 js_szy 的回复:]
引用 28 楼 ws_hgo 的回复:
小卒

若T2中没有T1的areaID,则areaCount为1,如T1表中的2001,在T2表中没有!!

也就是没有的时候为1
已经说啦!



我倒,题目没看完整。。。。。。。。。!!!BS自己一下。撤!
[/Quote]
华夏小卒 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 28 楼 ws_hgo 的回复:]
小卒

若T2中没有T1的areaID,则areaCount为1,如T1表中的2001,在T2表中没有!!

也就是没有的时候为1
已经说啦!

[/Quote]

我倒,题目没看完整。。。。。。。。。!!!BS自己一下。撤!
ws_hgo 2009-09-08
  • 打赏
  • 举报
回复
declare @TT table
(
areaID int identity(1,1) primary key,
[year] int
)
insert into @TT select 1999
insert into @TT select 1999
insert into @TT select 1999
insert into @TT select 2000
insert into @TT select 2000
insert into @TT select 2001

declare @T2 table
(
areaID int
)
insert into @T2 select 1
insert into @T2 select 1
insert into @T2 select 1
insert into @T2 select 2
insert into @T2 select 2
insert into @T2 select 4
insert into @T2 select 4
insert into @T2 select 4
insert into @T2 select 5


select T1.*,isnull(T2.areaCount,1) areaCount from
(
select [year],count([year]) yearCount from @TT group by [year]
)T1
left join
(
select [year],isnull(count(T2.areaID),1) areaCount from @T2 T2 join @TT T1 on T2.areaID=T1.areaID group by [year]
) T2
on T1.[year]=T2.[year]


year yearCount areaCount
----------- ----------- -----------
1999 3 5
2000 2 4
2001 1 1
ws_hgo 2009-09-08
  • 打赏
  • 举报
回复
小卒

若T2中没有T1的areaID,则areaCount为1,如T1表中的2001,在T2表中没有!!

也就是没有的时候为1
已经说啦!
华夏小卒 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 24 楼 ws_hgo 的回复:]
引用 21 楼 koukoujiayi 的回复:
10楼,18楼2001是0了!!
我希望为1!!
可能比较困难,

2001确实为0
用isnull(null,1)
看我8楼写的
[/Quote]

如果这样的话,倒是能接受。。。。
华夏小卒 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 21 楼 koukoujiayi 的回复:]
10楼,18楼2001是0了!!
我希望为1!!
可能比较困难,
[/Quote]


[Quote=引用 23 楼 ws_hgo 的回复:]
小卒
是为0

[/Quote]


我搞晕了,不知道到底是0,还是1了

楼主能说下,为什么2001的areaCount 的是1吗???

如果,你把2001, 6这个算一个得话


那1999,3 为什么不算一条呢,那1999且不是3+2+1=6条了
soft_wsx 2009-09-08
  • 打赏
  • 举报
回复
/*
Microsoft SQL Server 2008 (RTM) - 10.0.1600.22 (Intel X86) Jul 9 2008 14:43:34 Copyright (c)
1988-2008 Microsoft Corporation Enterprise Evaluation Edition on Windows NT 5.1 <X86>
(Build 2600: Service Pack 3)
愿和大家共同进步
如有雷同、实属巧合
●●●●●2009-09-08 18:06:23.640●●●●●
 ★★★★★soft_wsx★★★★★
*/
if OBJECT_ID('t1') is not null drop table t1
create table t1(year1 nvarchar(10),areaid int identity(1,1) primary key)
insert t1(year1)
select'1999'
union all select'1999'
union all select'1999'
union all select'2000'
union all select'2000'
union all select'2001'

if OBJECT_ID('t2') is not null drop table t2
create table t2(areaid int)
insert t2(areaid)
select 1
union all select 1
union all select 1
union all select 2
union all select 2
union all select 4
union all select 4
union all select 4
union all select 5
select year1,SUM(areaCount) as areaCount,MAX(yearcount) as yearcount
from(
select x.year1,areaCount=COUNT(b.areaid),yearcount=(select count(1) from t1 where year1=x.year1 and areaid>=a.areaid)
from (select distinct year1 from t1) x left join t1 a
on x.year1=a.year1
left join t2 b
on a.areaid=b.areaid
group by x.year1,a.year1,a.areaid
) a group by year1
/*
year1 areaCount yearcount
1999 5 3
2000 4 2
2001 0 1
*/
2000方法
ws_hgo 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 21 楼 koukoujiayi 的回复:]
10楼,18楼2001是0了!!
我希望为1!!
可能比较困难,
[/Quote]
2001确实为0
用isnull(null,1)
看我8楼写的
ws_hgo 2009-09-08
  • 打赏
  • 举报
回复

小卒
是为0
华夏小卒 2009-09-08
  • 打赏
  • 举报
回复
果果,我是说那个areaCount 的2001的为什么会是1
koukoujiayi 2009-09-08
  • 打赏
  • 举报
回复
10楼,18楼2001是0了!!
我希望为1!!
可能比较困难,
ws_hgo 2009-09-08
  • 打赏
  • 举报
回复
看错啦
ws_hgo 2009-09-08
  • 打赏
  • 举报
回复
[Quote=引用 17 楼 js_szy 的回复:]
引用 12 楼 ws_hgo 的回复:
引用 11 楼 js_szy 的回复:
奇怪 为什么2001的areaCount
会是1呢

是为1啊



t2 里不是没有2001对应的areaid=6的记录吗
怎么是1?

难道这也要左连接??? 我晕
[/Quote]

declare @TT table
(
areaID int identity(1,1) primary key,
[year] int
)
insert into @TT select 1999
insert into @TT select 1999
insert into @TT select 1999
insert into @TT select 2000
insert into @TT select 2000
insert into @TT select 2001
select [year],count([year]) yearCount from @TT group by [year]
year yearCount
----------- -----------
1999 3
2000 2
2001 1
加载更多回复(18)
Domain4.3(明小子)10.10.10更新版主要更新内容如下: 1.驱除部分死连接,恢复部分官方连接 2.改变默认显示页面为本人BLOG 3.修正程序在检测时出错的BUG 4.修正程序在部分系统中无法启动的BUG 5.加了一个功能模块,但还不成熟,隐藏了,高手的话可以用OD调出来!>!< 6.修复前段时间一些朋友反映的错误和程序宏 7.增加四款SKN皮肤! 10.10.11紧急更新: 1.修正新版程序在部分系统中启动后直接导致系统蓝屏的BUG 2.修正域名查询的几个错误 3.修正程序批量检测查询到域名的时候无反映的BUG! Domain4.2(明小子)10.01.16更新版主要更新内容如下: 1.删除所有无关数据 2.优化急速代码 3.改变启动线程 4.增加SQL数据批量导出功能 5.加入几个优化进程模块,非后门.后台运行. 6.锁定主程序栏目宽和高,不在恢复 7.删除“辅助工具”模块中全部代码 8.修正XP SP3 程序下兼容问题 9.重新改写域名查询旁站线程 程序于2010年01月16号调试完毕! 提别提示:第4个功能只能运行在完整版的windows XP 平台系统中,其他平台无法运行,如果出现恢复按钮并不能保存请自行调试与本程序无关.谢谢合作! 宝宝的话:有朋友们的鼓励才会有这个版本的发布,这当是我送给大家2010年里的第一个礼物吧。 Domain4.1(明小子)0901更新版主要更新内容如下: 1.增加新系统兼容模块,全面兼容2000-2008各系统 (部分精简版系统除外) 2.优化网站打开速度,删减部分无用内核信息,全面加快程序启动速度. 3.基于09.05.20号内核提升,改变搜查循环的一个死BUG! 4.删除在0520上增加的一个补针函数,并使用新的函数替换.保证不报错. 5.不在兼容xpsp3,因为没时间去修正这个错误。所以可能部分SP3系统运行不起来本程序 6.增加部分程序扩充空格代码,为下个版本更新做好铺垫 小提示:保留旧的IP反查连接系统,原因没有找到新的和稳定的IP反差服务器!如果有能提供的请与本人联系!谢谢合作 Domain4.1(明小子)0520更新版主要更新内容如下: 1.基于08.10.01号内核提升,修正一次关键错误。 2.替换原程序自带的那个小马,该为最新美化免杀版的小马! 3.添加一个服务器挂钩程序(非插件),使修改后的新内核兼容vista系统。 4.程序数据库默认名为:SetData.mdb 请大家使用3.5版本以上的MDB数据.其他低版本程序可能不兼容! 5.删除后台下载统计代码(以前没发现,本人也是从网站上面下的软件,排除作者自添加行为) 6.加了一个补针,针对sql注入功能中的一个小BUG。 7.删除了很多没有用的代码,最大限度的优化程序启动速度。 8.更新部分在xpsp3下出错的几个小BUG(小问题小解决,这个错误仅针对部分优化过度的XPSP3系统)。 提记:很多朋友说需要修改下程序IP域名查询功能,这里说明下.由于内核找不到关键句柄导致无法更新,下个版本在仔细看看! Domain4.0(明小子)1001更新版主要更新内容如下: 1.更新部分过度优化过的系统不兼容问题。 2.修改内存识别函数,使其降低软件在使用期间所占用的内存大小。 3.基于08.09.15号内核提升,修正因修改软件所出现的几个导致软件崩溃的几个BUG。 4.换了软件自带的那个垃圾皮肤。加入兼容美化皮肤!更美观! 5.兼容前版本数据库支持功能 6.去掉了没有用的PHP入侵选项和几处小BUG...... 转贴是一种美德!分享也是一种快乐,工具仅做辅助作用请勿用在非法用途上! 程序自带本BLOG连接,启动比较慢!不喜勿用!谢谢合作!

34,838

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧