--物品装箱问题
/*
http://topic.csdn.net/u/20100703/16/bcc2efaf-5aee-424d-b022-473282a168ae.html?seed=657778656&r=66694963#r_66694963
有一个表,字段为:物品名,件数。
记录: 物A 54
物B 35
物C 23
物D 98
物E 43
现要对这些物品统一装箱,统一装60个一箱,那么第一箱物A装54个,物B装6个,第二箱物B装29个,物C装23个,物D装8个,依此类推。
请问怎么解决?
*/
if object_id('[tb]') is not null drop table [tb]
go
create table [tb](物品名 varchar(10),件数 int)
insert [tb]
select '物A', 54 union all
select '物B', 35 union all
select '物c', 23 union all
select '物d', 98 union all
select '物e', 43
go
set nocount on
declare @物品 varchar(10),@数量 int,@箱号 int,@剩余 int
declare @t table(箱号 int,物品 varchar(10),数量 int)
declare cur cursor for select * from tb
open cur
fetch cur into @物品,@数量
set @箱号=1
while @@fetch_status=0
begin
while 1=1
begin
select @剩余=isnull(sum(数量),0) from @t where 箱号=@箱号
if @数量>60 - @剩余
begin
set @数量=@数量-(60 - @剩余)
insert @t select @箱号, @物品,60 - @剩余
set @箱号=@箱号+1
end
else
begin
insert @t select @箱号,@物品,@数量
break
end
end
fetch cur into @物品,@数量
end
close cur
deallocate cur
select * from @t
/*
箱号 物品 数量
----------- ---------- -----------
1 物A 54
1 物B 6
2 物B 29
2 物c 23
2 物d 8
3 物d 60
4 物d 30
4 物e 30
5 物e 13
*/
分享到:
相关推荐
SQL SERVER 字符集问题之一解决
SQL Server 2000相关问题SQL Server 2000相关问题SQL Server 2000相关问题SQL Server 2000相关问题SQL Server 2000相关问题SQL Server 2000相关问题SQL Server 2000相关问题
Microsoft SQL Server 2008 Native Client (SQL Server Native Client) 是单一动态链接库 (DLL),其中包含 SQL OLE DB 提供者和 SQL ODBC 驱动程序。此链接库针对使用机器码 API (ODBC、OLE DB 和 ADO) 的应用程序...
[Microsoft Press] Microsoft SQL Server 2012 技术内幕 (英文版) [Microsoft Press] Microsoft SQL Server 2012 Internals (E-Book) ☆ 图书概要:☆ Dive deep inside the architecture of SQL Server 2012 ...
SQLServer+ 免安装版 SQLServer+是在原有SQLServer2000的基础上改善了数据库安装的繁锁性,让软件企业在发布基于SQLServer2000数据库软件的时候,只要把软件打包进入安装包而不需要再单独安装数据库,也不需要另外...
SQL Server 2014基础入门视频教程 (40集,含课件) 1.SQL Server 2014简介.mp4 2.SQL Server 2014硬件和软件要求.mp4 3.SQL Server 2014数据库安装.mp4 4.SQL Server 2014数据库创建.mp4 5.SQL Server 2014...
SQLServer文件, 否则后果自负。作者不为您承担任何方面的任何责任。 SQL Server 2000绿色版注意事项 --------------------------- 1 本地连接服务器请使用界面中“服务器名”文本框中的文本作为服务器名连接...
SqlServer连接工具SqlServer连接工具SqlServer连接工具
sqlserver自动生成sql语句工具sqlserver转oracle
支持navicate 连接 sqlserver 2019 的 驱动sqlserver native client 11.0 ,亲测可用,ssms自带的不能连接,会报远程关闭错误。
解决oracle sqldeveloper无法连接mysql、SQLServer问题,sqlDeveloper是ORACLE数据库开发工具,自带的是无法连接MS SQL Server以及mysql的,想连接的话需要第三方工具。 使用方法: 解压出来后将2个jar放入jlib...
SQL Server 2005 移动版(SQL Server Mobile)或SQL Server 2000 Windows CE 2.0版(SQL Server CE 2.0)的企业和个人用户如果计划与SQL Server 2000或SQL Server 2005数据库保持同步,需要在您运行Microsoft ...
SQL Server 2016 Web BXJTY-X3GNH-WHTHG-8V3XK SQL Server 2016 Standard B9GQY-GBG4J-282NY-QRG4X SQL Server 2016 Enterprise Core TBR8B-BXC4Y-298NV-PYTBY SQL Server 2016 Enterprise MDCJV-3YX8N-WG89M-KV443...
sqlserver离线安装包
SQL server 2005安装问题及解决办法,自己积累的,绝对能解决问题,试试就知道
SQLServerAgent 这个服务已经启动了 “控制面板 -》管理->服务->SQLSERVERAGENT->设置为自动启动”—这个已经这是好了 但是问题依然存在,一启动作业就会提示: 错误22022:SQLServerAgent当前未运行,因此,无法就...
用于解决SQLSERVER连接问题驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接问题JAR包。
1.SQL Server 2014简介.mp4 10.SQL Server 2014定义表主键、外键.mp4 11.SQL Server 2014新增表记录.mp4 12.SQL Server 2014查询表记录.mp4 13.SQL Server 2014修改表记录.mp4 14.SQL Server 2014删除表记录....
sql server 2008 安装教程sql server 2008 安装教程sql server 2008 安装教程sql server 2008 安装教程sql server 2008 安装教程
Microsoft sql server 2008 Native Client (SQL Server Native Client) 是一个同时包含 SQL OLE DB 访问接口和 SQL ODBC 驱动程序的动态链接库 (DLL)。它对使用本机代码 API(ODBC、OLE DB 和 ADO)连接 Microsoft ...