--创建待使用的表格
CREATE TABLE Orders
(
OrderID INT ,
CostValue DECIMAL(18, 2)
);
WITH cte_temp
AS ( SELECT 1 AS OrderID
UNION ALL
SELECT OrderID + 1
FROM cte_temp
WHERE OrderID < 10000
)
INSERT INTO Orders
( OrderID
)
SELECT OrderID
FROM cte_temp
OPTION ( MAXRECURSION 32767 );
SELECT *
FROM dbo.Orders;
--UPDATE dbo.Orders SET CostValue=NULL
--用游标的方式填充数据 51s
GO
DECLARE @OrderID INT;
DECLARE cursor_CostValue CURSOR
FOR
SELECT OrderID
FROM dbo.Orders;
OPEN cursor_CostValue;
FETCH NEXT FROM cursor_CostValue INTO @OrderID;
WHILE @@FETCH_STATUS = 0
BEGIN
UPDATE dbo.Orders
SET CostValue = @OrderID + 100
WHERE OrderID = @OrderID;
FETCH NEXT FROM cursor_CostValue INTO @OrderID;
END;
CLOSE cursor_CostValue;
DEALLOCATE cursor_CostValue;
--使用while循环的方式 用时13s
GO
DECLARE @RowID INT;
--获取待处理的数据记录到临时表
--字段说明 RowID 记录的行号 DealFlg 行处理标识
SELECT RowID = IDENTITY( INT,1,1 ),
DealFlg = 0 ,
OrderID ,
CostValue = 0
INTO #Temp
FROM dbo.Orders;

SELECT @RowID = MIN(RowID)
FROM #Temp
WHERE DealFlg = 0;
--如果最小行号不为空 则表示有数据
WHILE @RowID IS NOT NULL
BEGIN
UPDATE #Temp
SET DealFlg = 1 ,
CostValue = OrderID + 100
WHERE RowID = @RowID;
SELECT @RowID = MIN(RowID)
FROM #Temp
WHERE DealFlg = 0;
END;
--此时 临时表中的costvalue已经被处理完毕
UPDATE a
SET a.CostValue = b.CostValue
FROM dbo.Orders a
JOIN #Temp b ON a.OrderID = b.OrderID;

sql中--行处理数据的两种方式的更多相关文章

  1. MVC中返回json数据的两种方式

    MVC里面如果直接将数据返回到前端页面,我们常用的方式就是用return view(): 那么我不想直接用razor语法,毕竟razor这玩意儿实在是太难记了,还不如写ajax对接来得舒服不是 那么我 ...

  2. SQL Server 2008 数据库同步的两种方式 (发布、订阅)

    参考转载: SQL Server 2008 数据库同步的两种方式 (发布.订阅) 使用Sqlserver事务发布实现数据同步

  3. strus2中获取表单数据 两种方式 属性驱动 和模型驱动

    strus2中获取表单数据 两种方式 属性驱动 和模型驱动 属性驱动 /** * 当前请求的action在栈顶,ss是栈顶的元素,所以可以利用setValue方法赋值 * 如果一个属性在对象栈,在页面 ...

  4. [Android] Android ViewPager 中加载 Fragment的两种方式 方式(二)

    接上文: https://www.cnblogs.com/wukong1688/p/10693338.html Android ViewPager 中加载 Fragmenet的两种方式 方式(一) 二 ...

  5. [Android] Android ViewPager 中加载 Fragment的两种方式 方式(一)

    Android ViewPager 中加载 Fragmenet的两种方式 一.当fragment里面的内容较少时,直接 使用fragment xml布局文件填充 文件总数 布局文件:view_one. ...

  6. .Net 中读写Oracle数据库常用两种方式

    .net中连接Oracle 的两种方式:OracleClient,OleDb转载 2015年04月24日 00:00:24 10820.Net 中读写Oracle数据库常用两种方式:OracleCli ...

  7. easyUI之datagrid绑定后端返回数据的两种方式

    先来看一下某一位大佬留下的easyUI的API对datagrid绑定数据的两种方式的介绍. 虽然精简,但是,很具有“师傅领进门,修行靠个人”的精神,先发自内心的赞一个. 但是,很多人和小编一样,第一次 ...

  8. SparkStreaming获取kafka数据的两种方式:Receiver与Direct

    简介: Spark-Streaming获取kafka数据的两种方式-Receiver与Direct的方式,可以简单理解成: Receiver方式是通过zookeeper来连接kafka队列, Dire ...

  9. SparkStreaming与Kafka,SparkStreaming接收Kafka数据的两种方式

    SparkStreaming接收Kafka数据的两种方式 SparkStreaming接收数据原理 一.SparkStreaming + Kafka Receiver模式 二.SparkStreami ...

随机推荐

  1. 外面的wifi非常精彩,外面的wifi非常不安

    星期一果然非常忙,看到安卓漏洞还是午休的时候.可能我们都习惯了.我们的信息安全一向难以得到保障.对于我来说,可能都无所谓了.可是作为用户之中的一个,我们也不能太安分,该须要的保障还是得维护. 本来.我 ...

  2. 在GitHub上使用Hexo搭建静态博客

    搭建静态博客须要一个前提是电脑上有安装git而且有github帐号,这个不懂能够看廖雪峰先生的git教程 1.下载nodejs.在官网上能够下载 2.使用git进入你新建的一个目录,输入命令 npm ...

  3. WPF获取和设置鼠标位置与progressbar的使用方法

    一.WPF 中获取和设置鼠标位置 方法一:WPF方法 Point p = Mouse.GetPosition(e.Source as FrameworkElement); Point p = (e.S ...

  4. linux 终端提示符

    默认的当路径一长就难看得出奇. 我的设置: export PS1="|\W$>\[\e[0m\]" 最后效果就是|目录名$> 参考:https://www.cnblog ...

  5. nyoj--233--Sort it (水题)

    Sort it 时间限制:1000 ms  |  内存限制:65535 KB 难度:2 描述 You want to processe a sequence of n distinct integer ...

  6. 理解class.forName()(good--字节码层面)

    使用jdbc方式连接数据库时会使用一句代码Class.forName(String className).这句话是什么意思呢?首先说一点Class.forName(String className)这 ...

  7. Java基础——protected访问修饰符探讨

    Java基础——protected访问修饰符探讨 根据官方说法:(如图) protected修饰符是可以修饰其他包中的子孙类的,但是我做了个实验,结果发现了一个有趣的现象! 具体请往下看: packa ...

  8. SQLServer 错误: 15404,维护计划无法执行

    错误症状: D:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\LOG下面的ERROELOG,用文本打,查看运行维维计划不成功是生成的错误日志详细信 ...

  9. HDU 1285 确定比赛名次【拓扑排序】

    题意:中文的题目-----这道题让我终于明白了那个break的作用---因为题目中有这一句“符合条件的排名可能不是唯一的,此时要求输出时编号小的队伍在前”@_@ #include<iostrea ...

  10. Python数据分析前提-----pandas

    1.read_csv(url):读取数据 2.help(read_csv):打印函数相关用法 3.数据名.dtypes:读取数据的类型(int.float……) 4.type(数据名):读取所有数据的 ...