以文本方式查看主题

-  Foxtable(狐表)  (http://www.foxtable.com/bbs/index.asp)
--  专家坐堂  (http://www.foxtable.com/bbs/list.asp?boardid=2)
----  [求助]关于结算起始日的求助  (http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&id=114225)

--  作者:huangfanzi
--  发布时间:2018/2/1 9:08:00
--  [求助]关于结算起始日的求助
公司发货存在次月结的情况,并且这个次月不一定是下月1号,可以是一个月中的任何一个日期,现假定表中有三个字段,希望根据结算日自动生成结算日期
字段说明:
发货日期 (日期型)
结算起始日(整数型,并且通过表事件限定了取值范围1-28)
结算日期(日期型)
样表:
发货日期       结算起始日     结算日期
2017-1-15         1             2017-2-1
2017-1-15        15           2017-2-15
2017-1-15        16            2017-1-16

请老师帮忙写个代码,让代码根据发货日与结算起始日自动计算出结算日期,谢谢!

--  作者:有点甜
--  发布时间:2018/2/1 9:13:00
--  

比如

 

Dim d1 As Date = "2017-1-15"
Dim d As Integer = 10
Dim d2 As Date = d1.addmonths(1)
d2 = new Date(d2.year, d2.month, d)
msgbox(d2)


--  作者:huangfanzi
--  发布时间:2018/2/1 9:16:00
--  
老师,这个代码不对的,我上面的例子难点在于
Dim d1 As Date = "2017-1-15"
Dim d As Integer = 16
Dim d2 As Date = d1.addmonths(1)
d2 = new Date(d2.year, d2.month, d)
msgbox(d2)

这时应该返回的日期是 2017-1-16
如果Dim d1 As Date = "2017-1-15"
Dim d As Integer = 14
Dim d2 As Date = d1.addmonths(1)
d2 = new Date(d2.year, d2.month, d)
msgbox(d2)
这里返回的值是 2017-2-14

--  作者:有点甜
--  发布时间:2018/2/1 9:20:00
--  
Dim d1 As Date = "2017-1-15"
Dim d As Integer = 16
Dim d2 As Date = d1
If d1.Day >= d Then
    d2 = d1.addmonths(1)
End If
d2 = new Date(d2.year, d2.month, d)
msgbox(d2)

--  作者:huangfanzi
--  发布时间:2018/2/1 9:49:00
--  
这个代码是可以了,但我实际用时是全用S elect语句中的,这样才更符合实际工作需要,请老师再帮我看看

例如有一合同表,结构包含以下字段:
合同号    结算日  单价
HT001     10      1

还有一个发货表,结构包含以下字段:

发货单号    发货重量   对应合同号     发货日
DH001         100       HT001      2017-1-2
DH002         150       HT001      2017-1-15

当前日期为2017-1-20
用的是SQL数据库,数据源名称:ErpSql  在窗口中有一table表及一个查询应收款的Button,希望点击这个Button将查询的数据写入这个table并得到如下结果:
发货单号  合同号  发货重量  发货金额  应收金额
DH001       HT001    100        100         100     因为此笔发货在当月10号之前,根据合同付款日应该在2017-1-10,所以客户应该付款了
DH002       HT001    150        150           0        因为此笔发货在当月10号之后,根据合同付款日应该在2017-2-10,所以客户暂时不用付款
这种情况应该用子查询得到应收金额,如何将楼上的代码改写成子查询,我对SQL语句实在能力有限,请老师帮忙写下,万分感谢!


[此贴子已经被作者于2018/2/1 9:51:23编辑过]

--  作者:有点甜
--  发布时间:2018/2/1 10:00:00
--  

select *,a.发货数量*b.单价 as 发货金额, (case when day(发货日) >= 结算日 then a.发货数量*b.单价 else 0 end) as 应收金额 from {发货表} a left join {合同表} b on a.对应合同号=b.合同号


--  作者:huangfanzi
--  发布时间:2018/2/1 10:24:00
--  
老师,day(发货日) >= 结算日 这个条件是不行的,就以上面例子为例
发货日是 2017-1-15
结算日是  每月10号
当前日期为2017-1-20时,上面的条件是成立的,但如果客户一直不付钱,当前的日期到了2017-2-20,哪这个客户就要付钱了,也就是说要这样判断:
day(发货日) >= 结算起始日期
这个结算起始日期又是通过4楼的代码算出来的,所以现在的问题是如何把4楼的代码所实现的功能搬到S elect中,我就是在这里不会

--  作者:有点甜
--  发布时间:2018/2/1 10:28:00
--  
发货表,加一列,是否已付,再作为条件判断此列。
--  作者:huangfanzi
--  发布时间:2018/2/1 10:40:00
--  
 是应该加一列,但不是加 是否已付,而是用4楼的代码放在表事件中自动计算出 结算起始日期,这样的话就老师的子查询语句就行了
--  作者:有点甜
--  发布时间:2018/2/1 11:00:00
--  

 

select *,a.发货数量*b.单价 as 发货金额, (case when day(发货日) >= 结算日 and DateDiff(d, DateAdd(m, 1, 发货日), GetDate()) >= 结算日-day(发货日) then a.发货数量*b.单价 Case when day(发货日) < 结算日 and DateDiff(d, 发货日, GetDate()) >= 结算日-day(发货日) then a.发货数量*b.单价 else 0 end) as 应收金额 from {发货表} a left join {合同表} b on a.对应合同号=b.合同号