100求助:分类汇总的问题,头都大了,请求帮助急!急!急!!!

ROMA_2008 2006-11-20 02:22:04
把销售表和结存表汇总成一个表

销售表:
日期 单据号码 客户名称 送货 开票
2006-1-2 送630 亨通 6
2006-1-12 送631 亨通 4
2006-1-16 送639 金田电工 6
2006-1-20 开237 云通电子 2
2006-1-21 开238 金田电工 4
2006-1-24 送642 长城高新 10

结存表:
客户名称 月份 结存
亨通 2005-12 4
云通电子 2005-12 3
金田电工 2005-12 8
长城高新 2005-12 1

现在要得到每个客户的销售汇总表(本期结存=上期结存+送货-开票)
日期 单据号码 客户名称 送货 开票 结存
上期结存 亨通 4
2006-1-2 送630 亨通 6
2006-1-12 送631 亨通 4
本期结存 亨通 6
上期结存 金田电工 8
2006-1-16 送639 金田电工 6
2006-1-21 开238 金田电工 4
本期结存 金田电工 10
上期结存 云通电子 3
2006-1-20 开237 云通电子 2
上期结存 云通电子 1
上期结存 云通电子 1
2006-1-24 送642 长城高新 10
本期结存 云通电子 11


...全文
224 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
playwarcraft 2006-11-20
  • 打赏
  • 举报
回复
create table sale(rq datetime,num varchar(20),customer varchar(30),send int,code int)
insert into sale
select '2006-01-02','送630','亨通',6,null union all
select '2006-01-12','送631','亨通',4,null union all
select '2006-01-16','送639','金田電子',6,null union all
select '2006-01-20','開237','雲通電子',null,2 union all
select '2006-01-21','開238','金田電子',null,4 union all
select '2006-01-24','送642','長城高新',10,null

create table locate(customer varchar(30),monthly varchar(07),value int)
insert into locate
select '亨通','2005-12',4 union all
select '雲通電子','2005-12',3 union all
select '金田電子','2005-12',8 union all
select '長城高新','2005-12',1

select * from
(select *,null as [結存] from sale
union all
select null,'上期結存',customer,null,null,value from locate
union all
select null,'本期結存',customer,null,null,sum(isnull(結存,0))+sum(isnull(send,0))-sum(isnull(code,0))
from
(select *,null as [結存] from sale
union all
select null,'上期結存',customer,null,null,value from locate) A
group by customer) T
order by customer,case when num='上期結存' then 1
when num='本期結存' then 3
else 2 end, rq

drop table sale,locate

上期結存 亨通 4
2006-01-02 00:00:00.000 送630 亨通 6
2006-01-12 00:00:00.000 送631 亨通 4
本期結存 亨通 14
上期結存 金田電子 8
2006-01-16 00:00:00.000 送639 金田電子 6
2006-01-21 00:00:00.000 開238 金田電子 4
本期結存 金田電子 10
上期結存 長城高新 1
2006-01-24 00:00:00.000 送642 長城高新 10
本期結存 長城高新 11
上期結存 雲通電子 3
2006-01-20 00:00:00.000 開237 雲通電子 2
本期結存 雲通電子 1
rea1gz 2006-11-20
  • 打赏
  • 举报
回复
seelct
-->
select
rea1gz 2006-11-20
  • 打赏
  • 举报
回复
declare @date datetime --参数
set @date='2006-1-1' --查一月

seelct 日期,单据号码,客户名称,送货,开票,结存
from (
select cast(null as datetime) as 日期,'上期结存' as 单据号码,客户名称,cast(null as int) as 送货,cast(null as int) as 开票,结存,
1 as type
from 结存表
where 月份=convert(varchar(7),dateadd(month,-1,@date)
union all
select 日期,单据号码,客户名称,送货,开票,cast(null as int) as 结存,
2 as type
from 销售表
where 日期>=@date and 日期<dateadd(month,1,@date)
union all
select null as 日期,'本期结存' as 单据号码,客户名称,null as 送货,null as 开票,sum(结存) as 结存,
3 as type
from (
select 客户名称,结存
from 结存表
where 月份=convert(varchar(7),dateadd(month,-1,@date)
union all
select 客户名称,isnull(送货,0)-isnull(开票,0) as 结存,
from 销售表
where 日期>=@date and 日期<dateadd(month,1,@date)
) as t
group by 客户名称
) as t1
order by 客户名称,type,日期
dulei115 2006-11-20
  • 打赏
  • 举报
回复
select 日期, 单据号码, 客户名称, 送货, 开票, 结存
from
(select 日期, 单据号码, 客户名称, 送货, 开票, cast(null as int) as 结存, 1 as 排序
from 销售表
union
select null, '上期结存', 客户, null, null, 结存, 0
from 结存表
union
select null, '本期结存', a.客户, null, null, a.结存 + sum(isnull(b.送货, 0)) - sum(isnull(a.开票, 0)), 2
from 结存表 a left join 销售表 b on a.客户 = b.客户名称
group by a.客户, a.结存) aa
order by 客户名称, 排序, 日期
ROMA_2008 2006-11-20
  • 打赏
  • 举报
回复
一定是上一期的
ROMA_2008 2006-11-20
  • 打赏
  • 举报
回复
其他月份类似,只要一个月统计出来,其他月份就好说了
playwarcraft 2006-11-20
  • 打赏
  • 举报
回复
時間概念不清,你的销售表是否只有1個月的資料?结存表是否一定是上期結存資料??
否則所謂的"期"的時間概念如何劃分??
内容概要:本文研究基于粒子群算法(PSO)优化模糊C均值聚类(FCM)的居民用电行为分析方法,提出一种改进的FCM聚类算法,通过引入粒子群优化机制,有效提升聚类性能与收敛效率,克服传统FCM算法易陷入局部最优、对初始聚类中心敏感等缺陷。研究基于Matlab平台实现算法代码,对居民用电负荷数据进行聚类分析,识别不同用户的典型用电模式与行为特征,进而支持电力系统的需求侧精细化管理、用户分群运营、个性化用电服务推荐以及中长期负荷预测。该方法在智能电网与大数据背景下展现出良好的应用前景,特别适用于大规模居民用电数据的行为挖掘与模式识别任务。; 适合人群:具备一定电力系统基础知识、数据挖掘或智能优化算法背景的科研人员及工程技术人员,尤其适合从事智能电网、负荷特性分析、需求响应、用户行为研究等方向的硕士、博士研究生及高校教师。; 使用场景及目标:①实现居民用户用电行为的有效分类与典型负荷曲线提取;②优化电力客户细分策略,支撑差异化电价、需求响应激励政策的设计与实施;③为负荷预测、电网规划、配电台区管理提供数据驱动的决策依据;④作为高水平学术论文(如EI、SCI期刊)的研究基础,用于算法复现、性能对比与创新改进。; 阅读建议:建议读者结合提供的Matlab代码深入理解PSO-FCM算法的具体实现流程,重点关注粒子编码方式、适应度函数构建、聚类有效性评价指标(如轮廓系数、误差平方和)的应用,鼓励在真实用电数据集上进行实验验证,并尝试引入其他优化策略或评估维度以进一步提升模型鲁棒性与实用性。
【重要提示】本资源设置为0积分下载,若非0积分请勿轻易下载 亲爱的CSDN用户: 首先感谢你点进这个资源页面。我需要提前说明一个重要情况: 本资源原本已设置为“0积分下载”,即作者希望完全免费共享。但CSDN平台有时会根据文件的下载热度、文件大小、用户权限等因素,自动将部分资源的积分调整为非0数值(如1积分、2积分、5积分等)。这是平台系统的自动行为,而非作者本人的设定。 因此,如果你当前看到该资源的下载所需积分不是0(例如显示为1、2、3……),请谨慎决定是否下载。 如果你按照非0积分支付并下载后发现资源内容不符合预期、链接失效,或者实际上该资源本应是免费的,作者无法为此承担积分损失或退还操作。强烈建议:仅在页面显示为0积分时进行下载。 另外,本资源描述中并未直接提供具体的下载地址或外部链接,因为它本身是一个通过CSDN官方上传通道提交的文件/内容包。如果你看到描述中没有外部网盘地址,这是正常的——资源文件应通过CSDN内置的“下载”按钮获取。若因平台积分显示异常导致你支付了积分,请优先联系CSDN客服咨询积分退还政策,作者没有权限修改平台自动设定的积分值。 感谢你的理解与支持。技术分享本应开放,但受限于平台规则,特此提醒如上。祝学习进步!
代码转载自:https://pan.quark.cn/s/a1913ccaa47a 在信息技术领域中,图像处理占据着核心地位,特别是在嵌入式系统以及移动设备上,由于受到资源条件的制约,常常需要将高分辨率的图像格式转化为低分辨率的格式,以此来提升显示效能和存储容量。"bmp格式转为rgb565格式图片转换工具"正是为了应对这种需求而研发的。BMP(Bitmap)是一种广泛应用的位图格式,它完整地记录了图像的每一个像素点信息,涵盖了色彩深度、透明度等参数。然而,这种格式在内存消耗和处理速率方面并不具备优势,尤其是在需要高速渲染的情境下。RGB565是一种16位的色彩编码格式,普遍应用于嵌入式系统,例如由微控制器控制的LCD显示屏。它通过分配5位红色、6位绿色以及5位蓝色分量来表现色彩,总共能够呈现2^16 = 65536种色彩,尽管其色彩数量(约1670万种)少于BMP的24位色彩,但足以满足绝大多数显示场景,并且显著降低了数据存储和传输的负担。这种转换工具的运作机制在于读取BMP文件中的每一个像素点,然后依照RGB565的编码规范重新组织色彩信息。在BMP文件中,像素数据一般以行为单位进行存储,遵循从左到右、自下而上的顺序。而在RGB565格式中,每个像素点由两个字节构成,其中红色和蓝色各占5位,绿色占据6位,这样的布局旨在提升内存中的对齐效率。转换流程通常包括以下几个环节:1. 分析BMP文件部:BMP文件部包含了图像的宽度、高度、色彩深度等关键数据,这是进行转换的依据。2. 获取像素数据:按照BMP文件的结构读取每一行的像素点信息。3. 色彩转换:将每个24位RGB色彩点转换为16位RGB565格式。4. 输出新格式:将转换后的RGB565数据写入新的...
内容概要:本文系统研究了基于合作博弈理论的综合能源系统利益分配优化调度方法,并配套提供了完整的Matlab代码实现。针对多个能源主体协同运行场景下的利益分配难题,文章构建了严谨的合作博弈模型,结合优化调度算法,在实现系统整体经济效益最大化的同时,确保各参与方之间的利益分配公平合理。研究内容涵盖模型的数学建模、理论推导、求解流程设计及仿真验证全过程,重点突出了Shapley值等经典博弈分配方法在能源系统中的应用,具有较强的理论深度与工程实践价值,适用于致力于高水平学术研究(如EI/SCI论文撰写)的科研人员。; 适合人群:具备电力系统、优化理论及博弈论基础知识,从事综合能源系统调度、分布式能源协同管理、能源互联网经济性分析等方向研究的硕士、博士研究生及高校科研人员。; 使用场景及目标:①用于多主体综合能源系统中利益分配机制的设计与仿真分析;②支撑高质量学术论文的撰写、复现与创新;③为实际能源项目中的协调调度决策与经济性评估提供理论依据与技术工具支持。; 阅读建议:建议读者结合Matlab代码逐模块研读,深入理解合作博弈模型与优化调度算法的耦合逻辑,重点关注Shapley值等分配机制的计算实现,并可通过调整参数或拓展模型结构进行二次开发与对比实验。

27,581

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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