您现在的位置: 爱51代码网 >> 范文 >> 文章正文
SQL 怎样在原表将一条数据根据数量字段拆分

比如我现在有一个表A,
A01(流水号)      A02(编号)     A03(数量)  A04(条码)
--------------------------------------------------------------------------------
1                               a001                  3                      14001
。。。

想要得到如下结果:原记录不删除,然后生成三条记录,编号不变,数量全部是1,只有条码是按规律自动增:
A01(流水号)      A02(编号)     A03(数量)  A04(条码)
--------------------------------------------------------------------------------
1                               a001                  1                      14001
2                               a001                  1                      14002
3                               a001                  1                      14003
。。。
----------------------------------------------------------------
--> 测试数据[A]
if object_id('[A]') is not null drop table [A]
go
create table [A]([A01] int,[A02] nvarchar(8),[A03] int,[A04] int)
insert [A]
select 1,'a001',3,14001
--------------生成数据--------------------------
 
    
select ROW_NUMBER()OVER(ORDER BY GETDATE())[A01],A02,1 A03,A04
from [A] CROSS JOIN (SELECT  number
FROM    master..spt_values
WHERE   number >= 1
        AND number <= ( SELECT  [A03]
                        FROM    a
                      )
        AND [type] = 'P')b
----------------结果----------------------------
/*
A01                  A02      A03         A04
-------------------- -------- ----------- -----------
1                    a001     1           14001
2                    a001     1           14001
3                    a001     1           14001
*/

  • 上一篇文章:

  • 下一篇文章: 没有了
  • 最新文章 热点文章 相关文章
    redhat 2.6 (santigo 5.6) vsftp
    shell如何实现自动填写操作执行下
    linux shell 文件配置sh:color:
    shell script语法一定要加path吗
    SecureCRT如何访问虚拟机vmWare中
    C#如何读取WINDOWS的放大系数
    cximge的图如何存入数据库并提取
    DBGRID控件显示查询结果文本类型
    TChart控件如何把表中右边的系列
    fastreport提示没有找到fr_class
    cximge的图如何存入数据库并提取
    linux下编译faac及faad2提示 rec
    accept无法获取客户端ip
    TClientDataSet如何避免多人更新
    如何用delphi代码修改XML节点
    vc++ pvoid *用delphi怎么表达
    GIS用百度行政区域的经纬度直接画
    不小心卸载了.net 4 extend,vs2
    C#byte【】里的数转换成string时
    C#的session取不到值
    SQL日期转换成英文并赋值给某
    sqlserver存储过程执行后变量
    sql server 2008到安装程序支
    sqlserver类型改成bigint了是
    sqlserver游标慢怎么办
    SQL SERVER 2000 作业节假日
    如何同时查询2个库的表进行对
    excel连接mssql2012中文乱码
    sqlserver判断一张表的某个字
    sql server 2008R2如何实现自
     



    设为首页 | 加入收藏 | 网站地图 | 友情链接 |