请教一个SQL查询问题 - MS-SQL Server / 基础类
希望能够得到高效率的解决办法,非常感谢!
SQL code:
表1:
编号 贷款金额 贷款日期
01 1000 2010-05-13
02 2000 2010-05-14
表2:
编号 还款金额 还款日期
01 100 2010-05-15
01 200 2010-05-16
01 300 2010-05-17
01 300 2010-05-19
01 100 2010-05-20
02 2000 2010-05-21
求出贷款日平均金额:
日期 日平均金额
2010-05-13 1000
2010-05-14 3000
2010-05-15 2900
2010-05-16 2700
2010-05-17 2400
2010-05-18 2400
2010-05-19 2100
2010-05-20 2000
2010-05-21 0
1楼的少了2010-05-18这一条记录
似乎只能是先建一个临时表,生成一个包含介于最小日期和最大日期的表,然后再更新金额字段
没看懂结果.
xys_777 的代码很好,但是缺少了18号这一天的数据。
另外,如果希望显示到2010-05-21到2010-05-31的数据,也都顺延最后那一天的余额到剩余的每一天,应该如何写?
替换一下子查询
SQL code:
select convert(varchar(10),t1.日期,120) 日期,sum(t2.金额) as 金额
from
(
select b.金额,a. 日期 f
相关问答:
请教高手:
以下是数据库中的三条记录,英文为字段名称
id planname TaskBeginTime Status
329 2010年03 ......
需求如下:
学院 academy(aid,aname)
班级 class(cid,cname,aid)
学生 stu(sid,sname,aid,cid)
住宿区 region(rid,rname)
宿舍楼 build(bid,rid,bnote) bnote是‘男’/‘女’
宿舍 dorm(did,rid,bid,bedn ......
我觉得mysql和sqlserver有共同的地方:
有个问题是关于表的锁问题:
进程A 进程B
select * from user where id in lock share mode(共享锁)
&nb ......
查询学生平均成绩及其名次
SELECT 1+(SELECT COUNT( distinct 平均成绩)
from (SELECT S#,AVG(score) AS 平均成绩
from SC&n ......
原SQL语句SQL code:
SELECT t6.FName '操作工',t1.FDate '日期',t5.FName '制单人',t3.FName '设备',t4.FName '班制',
t7.FBillNo '工艺指令单号',t8.FName '岗位',t2. ......