Sql Server使用cursor处理重复数据过程详解

/************************************************************
 * Code formatted by setyg
 * Time: 2014/7/29 10:04:44
 ************************************************************/ 

CREATE PROC HandleEmailRepeat
AS
DECLARE email CURSOR
FOR
  SELECT e.email
     ,e.OrderNo
     ,e.TrackingNo
  FROM  Email20140725 AS e
  WHERE e.[status] = 0
  ORDER BY
      e.email
     ,e.OrderNo
     ,e.TrackingNo 

BEGIN
  DECLARE @@email       VARCHAR(200)
      ,@firstEmail     VARCHAR(200)
      ,@FirstOrderNO    VARCHAR(300)
      ,@FirstTrackingNO   VARCHAR(300)
      ,@NextEmail      VARCHAR(200)
      ,@@orderNO      VARCHAR(300)
      ,@NextOrderNO     VARCHAR(50)
      ,@@trackingNO     VARCHAR(300)
      ,@NextTrackingNO   VARCHAR(50) 

  BEGIN
    OPEN email;
    FETCH NEXT FROM email INTO @firstEmail,@FirstOrderNO, @FirstTrackingNO;
    FETCH NEXT FROM email INTO @NextEmail,@NextOrderNO, @NextTrackingNO;
    IF @NextEmail!=@firstEmail
    BEGIN
      INSERT INTO Email20140725Test
       (
        email
        ,OrderNo
        ,TrackingNo
       )
      VALUES
       (
        @firstEmail
        ,@FirstOrderNO
        ,@FirstTrackingNO
       );
      SET @@email = @NextEmail;
      SET @@orderNO = @NextOrderNO;
      SET @@trackingNO = @NextTrackingNO;
    END
    ELSE
    BEGIN
      SET @@email = @NextEmail;
      SET @@orderNO = @FirstOrderNO+'、'+@NextOrderNO;
      SET @@trackingNO = @FirstTrackingNO+'、'+@NextTrackingNO;
    END 

    FETCH NEXT FROM email INTO @NextEmail,@NextOrderNO,@NextTrackingNO
    WHILE @@fetch_status=0
    BEGIN
      IF @NextEmail=@@email
      BEGIN
        IF (@NextOrderNO!=@@orderNO)
          SET @@orderNO = @@orderNO+'、'+@NextOrderNO 

        PRINT 'orderNO:'+@@orderNO  

        IF (@@trackingNO!=@NextTrackingNO)
          SET @@trackingNO = @@trackingNO+'、'+@NextTrackingNO 

        PRINT 'trackingNO:'+@@trackingNO
      END
      ELSE
      BEGIN
        INSERT INTO Email20140725Test
         (
          email
          ,OrderNo
          ,TrackingNo
         )
        VALUES
         (
          @@email
          ,@@orderNO
          ,@@trackingNO
         );
        SET @@email = @NextEmail;
        SET @@orderNO = @NextOrderNO;
        SET @@trackingNO = @NextTrackingNO;
      END
      FETCH NEXT FROM email INTO @NextEmail,@NextOrderNO, @NextTrackingNO;
    END
    CLOSE email; --关闭游标
    DEALLOCATE email; --释放游标
  END
END
(0)

相关推荐

  • SQL Server数据库删除数据集中重复数据实例讲解

    SQL Server数据库操作中,有时对于表中的结果集,满足一定规则我们则认为是重复数据,而这些重复数据需要删除.如何删除呢?本文我们通过一个例子来加以说明. 例子如下: 如下只要companyName,invoiceNumber,customerNumber三者都相同,我们则认为是重复数据,下面的例子演示了如何删除. declare @InvoiceListMaster table ( ID int identity primary key , companyName Nchar(20), i

  • sqlserver合并DataTable并排除重复数据的通用方法分享

    代码如下: 复制代码 代码如下: ///<summary> /// 将两个列不同的DataTable合并成一个新的DataTable ///</summary> ///<param name="dt1">源表</param> ///<param name="dt2">需要合并的表</param> ///<param name="primaryKey">需要排重列表

  • SQL Server中删除重复数据的几个方法

    方法一 复制代码 代码如下: declare @max integer,@id integer declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) > 1 open cur_rows fetch cur_rows into @id,@max while @@fetch_status=0 begin select @max = @max -1 set rowcount

  • sqlserver清除完全重复的数据只保留重复数据中的第一条

    --创建测试表 CREATE TABLE [dbo].[testtab]( [id] [nchar](10) NULL, [name] [nchar](10) NULL ) ; --向测试表插入测试数据 insert into testtab values('1','1'); insert into testtab values('1','1'); insert into testtab values('2','2'); insert into testtab values('2','2');

  • MSSql简单查询出数据表中所有重复数据的方法

    本文实例讲述了MSSql简单查询出数据表中所有重复数据的方法.分享给大家供大家参考,具体如下: 这里直接给出下面的例子: SELECT * FROM SYS_LogContent slc WHERE slc.LogInfo_ID IN ( SELECT slc2.LogInfo_ID FROM SYS_LogContent slc2 GROUP BY slc2.LogInfo_ID HAVING COUNT(*)>1 ) 简单说明: 关键代码在于上面的括号中.要想查询出所有重复的数据,可以按照某

  • 教你几种在SQLServer中删除重复数据方法

    方法一 复制代码 代码如下: declare @max integer,@id integer declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) > 1 open cur_rows fetch cur_rows into @id,@max while @@fetch_status=0 begin select @max = @max -1 set rowcount

  • sqlserver中重复数据值只取一条的sql语句

    复制代码 代码如下: --建立数据表createtable TestData ( ID int identity(1,1) primary key, Data int, ColA varchar(20), ColB varchar(20) ) go --插入测试数据 declare @counts int declare @i int set @counts = 10000 set @i = 1 while @i<=@counts begin insert TestData (Data,ColA

  • Sql Server使用cursor处理重复数据过程详解

    /************************************************************ * Code formatted by setyg * Time: 2014/7/29 10:04:44 ************************************************************/ CREATE PROC HandleEmailRepeat AS DECLARE email CURSOR FOR SELECT e.email

  • Sql Server 开窗函数Over()的使用实例详解

    利用over(),将统计信息计算出来,然后直接筛选结果集 declare @t table( ProductID int, ProductName varchar(20), ProductType varchar(20), Price int) insert @t select 1,'name1','P1',3 union all select 2,'name2','P1',5 union all select 3,'name3','P2',4 union all select 4,'name4

  • JDBC连接MySQL数据库批量插入数据过程详解

    这篇文章主要介绍了JDBC连接MySQL数据库批量插入数据过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1.读取本地json数据 2.jdbc理解数据库 3.批量插入 maven 引入jar包: <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2

  • SQL Server中identity(自增)的用法详解

    一.identity的基本用法 1.含义 identity表示该字段的值会自动更新,不需要我们维护,通常情况下我们不可以直接给identity修饰的字符赋值,否则编译时会报错 2.语法 列名 数据类型 约束 identity(m,n) m表示的是初始值,n表示的是每次自动增加的值 如果m和n的值都没有指定,默认为(1,1) 要么同时指定m和n的值,要么m和n都不指定,不能只写其中一个值,不然会出错 3.实例演示 不指定m和n的值 create table student1 ( sid int p

  • postgresql 删除重复数据案例详解

    1.建表 /* Navicat Premium Data Transfer Source Server : localhost Source Server Type : PostgreSQL Source Server Version : 110012 Source Host : localhost:5432 Source Catalog : postgres Source Schema : public Target Server Type : PostgreSQL Target Server

  • MySQL 去除重复数据实例详解

    MySQL 去除重复数据实例详解 有两个意义上的重复记录,一是完全重复的记录,也即所有字段均都重复,二是部分字段重复的记录.对于第一种重复,比较容易解决,只需在查询语句中使用distinct关键字去重,几乎所有数据库系统都支持distinct操作.发生这种重复的原因主要是表设计不周,通过给表增加主键或唯一索引列即可避免. select distinct * from t; 对于第二类重复问题,通常要求查询出重复记录中的任一条记录.假设表t有id,name,address三个字段,id是主键,有重

  • JavaScript处理解析JSON数据过程详解

    JSON (JavaScript Object Notation)一种简单的数据格式,比xml更轻巧. JSON 是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON 数据不需要任何特殊的 API 或工具包. JSON的规则很简单: 对象是一个无序的"'名称/值'对"集合.一个对象以"{"(左括号)开始,"}"(右括号)结束.每个"名称"后跟一个":"(冒号):"

  • java 查找list中重复数据实例详解

    java 查找list中重复数据实例详解 需求: 查找一个List集合中所有重复的数据,重复的数据可能不止一堆,比如:aa, bb, aa, bb, cc , dd, aa这样的数据.如果有重复数据,则给这些重复数据加上编号,上述数据改为:aa1, bb1, aa2, bb2, cc, dd. 算法如下: public static void same(List<String> list) { String [] indexArr ; Map<String, String> map

  • SPRINGBOOT读取PROPERTIES配置文件数据过程详解

    这篇文章主要介绍了SPRINGBOOT读取PROPERTIES配置文件数据过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 一.使用@ConfigurationProperties来读取 1.Coffer entity @Configuration @ConfigurationProperties(prefix = "coffer") @PropertySource("classpath:config/coffer.p

  • 破解IDEA(Goland)注册码设置 license server一直有效不过期的过程详解

    原文地址:https://blog.csdn.net/animatecat/article/details/81483174 PS:2018年9月10日 目前jar包为:JetbrainsCrack-3.1-release-enc.jar 破解的详细过程: 1.从下面地址下载一个jar包,名称是  JetbrainsCrack-2.10-release-enc.jar 下载地址是http://idea.lanyus.com/,进去之后点击这个网址 . 2.将你下载好的JetbrainsCrack

随机推荐