一个两表联合查询的问题!

秀小川 2012-10-17 09:55:40
有两张表
表1存储用户的基本信息
"userid" (主键)
"用户姓名"
.
.
.
表2:存储所用用户的购买信息
"userid"
"时间"
"购买金额"

现在是想查询某位用户具体的 "姓名", "最近一次消费记录", "平均每月消费金额"该怎样去做这样的一个查询?知道具体的userid

...全文
122 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
IEEE_China 2012-10-17
  • 打赏
  • 举报
回复

declare @userid int
declare @avgMoney decimal(12,2)
set @userid=4---这里取你要查询的用户ID

CREATE TABLE #a(
[ID] [int] IDENTITY(1,1) NOT NULL,
[userid] [int] NULL ,
[用户姓名][nvarchar](50) NULL

)
CREATE TABLE #b(
[ID] [int] IDENTITY(1,1) NOT NULL,
[userid] [int] NULL ,
[时间] datetime NULL,
[购买金额] decimal(12,2) NULL

)

insert into #a
select 1,'张三' union all
select 2,'李四' union all
select 3,'王五' union all
select 4,'赵六'

insert into #b
select 1,'2012-01-01',10.00 union all
select 1,'2012-02-01',20.00 union all
select 1,'2012-03-01',30.00 union all
select 1,'2012-04-01',40.00 union all
select 2,'2012-01-01',10.00 union all
select 2,'2012-02-01',100.00 union all
select 2,'2012-03-01',200.00 union all
select 2,'2012-04-01',300.00 union all
select 3,'2012-01-01',111.00 union all
select 3,'2012-02-01',222.00 union all
select 3,'2012-03-01',333.00 union all
select 3,'2012-04-01',444.00 union all
select 4,'2012-01-01',1.00 union all
select 4,'2012-02-01',2.00 union all
select 4,'2012-03-01',3.00 union all
select 4,'2012-04-01',4.00


select @avgMoney =(select sum(购买金额)/datediff(m,min(时间),max(时间)) from #b where userid=@userid)
select top 1 a.用户姓名,b.时间,b.购买金额, @avgMoney 平均每月消费
from #a a join #b b on a.userid=b.userid
where a.userid=@userid
order by b.时间 desc

drop table #a
drop table #b

---查询结果
(4 行受影响)

(16 行受影响)

(1 行受影响)

----------------------------------------
用户姓名 时间 购买金额 平均每月消费

赵六 2012-04-01 00:00:00.000 4.00 3.33

秀小川 2012-10-17
  • 打赏
  • 举报
回复
或许我表达没表达清楚,
"平均每月消费"是这个意思: 用户一个月可能有多次消费,也可能几个月消费一次!` 这里平均每个月就是所有的消费金额加起来 除以 第一次消费到当前时间间隔的月数!
IEEE_China 2012-10-17
  • 打赏
  • 举报
回复
求平均消费可以和最后一条消费记录写在一起,
每月平均消费????
唐诗三百首 2012-10-17
  • 打赏
  • 举报
回复

-- 最近一次消费记录
select b.用户姓名,a.时间,a.购买金额
from 表2 a
inner join 表1 b on a.userid=b.userid
inner join
(select userid,max(时间) '时间'
from 表2 where userid=[userid]) c
on a.userid=c.userid and a.时间=c.时间
where a.userid=[userid]

-- 平均每月消费金额
select b.用户姓名,
rtrim(datepart(mm,a.时间))+'月' '月份',
avg(a.购买金额) '平均消费金额'
from 表2 a
inner join 表1 b on a.userid=b.userid
where a.userid=[userid]
group by datepart(mm,a.时间)
以学习为目的 2012-10-17
  • 打赏
  • 举报
回复
楼主测试下楼上的
IEEE_China 2012-10-17
  • 打赏
  • 举报
回复


declare @userid int
set @userid=3---这里取你要查询的用户ID

CREATE TABLE #a(
[ID] [int] IDENTITY(1,1) NOT NULL,
[userid] [int] NULL ,
[用户姓名][nvarchar](50) NULL

)
CREATE TABLE #b(
[ID] [int] IDENTITY(1,1) NOT NULL,
[userid] [int] NULL ,
[时间] datetime NULL,
[购买金额] decimal(12,2) NULL

)

insert into #a
select 1,'张三' union all
select 2,'李四' union all
select 3,'王五' union all
select 4,'赵六'

insert into #b
select 1,'2012-01-01',10.00 union all
select 1,'2012-02-01',21.00 union all
select 1,'2012-03-01',32.00 union all
select 1,'2012-04-01',43.00 union all
select 2,'2012-01-01',10.00 union all
select 2,'2012-02-01',24.00 union all
select 2,'2012-03-01',35.00 union all
select 2,'2012-04-01',46.00 union all
select 3,'2012-01-01',10.00 union all
select 3,'2012-02-01',25.00 union all
select 3,'2012-03-01',34.00 union all
select 3,'2012-04-01',43.00 union all
select 4,'2012-01-01',10.00 union all
select 4,'2012-02-01',22.00 union all
select 4,'2012-03-01',33.00 union all
select 4,'2012-04-01',44.00



select top 1 a.用户姓名,b.时间,b.购买金额,(select avg(购买金额) from #b where userid=@userid) 平均消费
from #a a join #b b on a.userid=b.userid
where a.userid=@userid
order by b.时间 desc

drop table #a
drop table #b

-----查询结果

用户姓名 时间 购买金额 平均消费
王五 2012-04-01 00:00:00.000 43.00 28.000000


(4 行受影响)

(16 行受影响)

(1 行受影响)

  • 打赏
  • 举报
回复
求:最近一次消费记录", "平均每月消费金额"
--》》最好写成两个sql。最近一次消费记录是一条,而每月平均消费金额可能是多条记录,写不到一块去。

最近一次消费记录",
select 姓名,时间,购买金额
from tb t
where not exists(select 1 from tb wher 姓名=t.姓名 and 时间>t.时间)

平均每月消费金额":
select 姓名,convert(char(8),时间),avg(金额)
from tb
group by 姓名,convert(char(8),时间)
IEEE_China 2012-10-17
  • 打赏
  • 举报
回复
昨天你不是问了这个问题了么
秀小川 2012-10-17
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 的回复:]

SQL code

declare @userid int
declare @avgMoney decimal(12,2)
set @userid=4---这里取你要查询的用户ID

CREATE TABLE #a(
[ID] [int] IDENTITY(1,1) NOT NULL,
[userid] [int] NULL ,
[用户姓名][nvarchar](50……
[/Quote]
谢谢了,就是这样的!

34,587

社区成员

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

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