注册 登录
编程论坛 ASP技术论坛

如何在搜索相关数据并同时得到某个字段的总和

yangliangy 发布于 2008-03-05 11:50, 1482 次点击
如下语句:就是一个查询两日期之间所有数据的sql,我想得到支出和收入的总和,用了sum函数,select sum(z_money) as z_m,sum(s_money) as s_m,[date] from [product],没有效果,用了group by having也是没有效果,是不是需要另外新建一个rs记录集,请高人指教
12 回复
#2
yangliangy2008-03-05 11:50
if isnull(keytext) or keytext="" then
    sql = sql
else
    if isnull(keytext2) or keytext2="" then
        sql = sql & " where [date] = #"&keytext&"#"
    else
        sql = sql & " where [date] between #"&keytext&"# and #"&keytext2&"#"
    end if
end if

[[it] 本帖最后由 yangliangy 于 2008-3-5 14:15 编辑 [/it]]
#3
madpbpl2008-03-05 12:26
已经解决了?没看出2#写得程序的意思,感觉逻辑上有些问题
#4
yangliangy2008-03-05 14:13
2#的程序只是搜索那部分功能,求记录和的不晓得怎样弄,还望指教.
#5
madpbpl2008-03-05 15:13
acc还是mssql数据库?
#6
yangliangy2008-03-05 15:35
ac数据库,对group by having不是很了解
#7
madpbpl2008-03-05 15:36
收入+支出          日期
14                  2008-3-4
0                   2008-3-3
53                  2008-3-2
楼主想要这样的结果?
#8
yangliangy2008-03-05 16:33
不是,这个比较简单,两个rs("shouru")+rs("zhichu")就行了,我想要那种结果,如上图,就是当我现在搜索的是3月1号到3月10号的记录,就显示3月1号到3月10号支出总和和收入总和
#9
madpbpl2008-03-05 16:52
收入+支出        
0                  
67
这样的结果?
sql ="select sum(z_money) as z_m,sum(s_money) as s_m from product where [date] between '2008-3-1' and '2008-3-10'"
#10
yangliangy2008-03-05 17:07
是的,要的是这样的结果,如下:
从2008-3-1到2008-3-5 支出总计:100 收入总计:100

我先前也是用过和你一样的SQL,但没有效果,是不是select那里只查询z_money和s_money两个字段,而后面的where语句的条件是date字段,记得where语句中的字段在select查询里面一定要包含是么???
#11
madpbpl2008-03-05 17:31
[bo]以下是引用 [un]yangliangy[/un] 在 2008-3-5 17:07 的发言:[/bo]

是的,要的是这样的结果,如下:
从2008-3-1到2008-3-5 支出总计:100 收入总计:100

我先前也是用过和你一样的SQL,但没有效果,是不是select那里只查询z_money和s_money两个字段,而后面的where语句的条件是date字段,记 ...

不一定,可能是哪里写错了。
#12
yangliangy2008-03-05 21:57
搞定了,新加了一个rs,好象用一个rs无法实现(即要显示每天的支出,收入记录,又要显示总和),一个用于显示所有记录(一条一条的),另一个rs显示支出的总和与收入的总和.如图1,图2
#13
madpbpl2008-03-06 12:58
能解决就好,估计一条sql也可以实现的。只是还是没理解楼主想要的结果。
1