--创建待使用的表格
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. php 设计模式之工厂模式

    php 设计模式之工厂模式 简介: 在开发大型系统过程中,往往会出现这样一种情况: 我有一部分基础数据,是类classA是从数据库A读取出来的,其他很多的功能都是基于这个基础数据来操作的.现在呢,我想 ...

  2. nyoj--1036--非洲小孩(区间相交问题)

    非洲小孩 时间限制:1000 ms  |  内存限制:65535 KB 难度:2 描述 家住非洲的小孩,都很黑.为什么呢? 第一,他们地处热带,太阳辐射严重. 第二,他们不经常洗澡.(常年缺水,怎么洗 ...

  3. word-wrap与word-break的区别,以及无效情况

    两种方法的区别说明: 1,word-break:break-all 例如div宽400px,它的内容就会到400px自动换行,如果该行末端有个英文单词很长(congratulation等),它会把单词 ...

  4. 读 Real-Time Rendering 收获 - chapter 4. transform

    chapter 4. Transform p54 affine transform p57 all rotation matrices have a determinant of one and ar ...

  5. SQL之子查询

    子查询概念:把一个查询的结果在另一个查询中使用就叫做子查询 1.子查询作为条件时 当我们使用子查询作为条件时,若子查询返回值为多个,则会报以下错误: "子查询返回的值不止一个.当子查询跟随在 ...

  6. js或者jq 使用cookie 时在谷歌浏览器不好使

    用js或者jq 写cookie时在谷歌浏览器上打开,cookie不能正常使用. 原因:浏览器没有开启cookie,打开cookie 就可以显示 其次,当将代码上传至服务器,再用浏览器打开时,cooki ...

  7. RocketMQ学习笔记(3)----RocketMQ物理结构和逻辑部署结构

    1. RocketMQ的物理结构 RecketMQ网络部署的特点: Name Server是一个几乎无状态特点,可集群部署,节点之间无任何信息同步的(相对于zookeeper是较为轻量级的). Bro ...

  8. 贰、js的基础(三)数组

    JS中数组的操作 1.数组的创建 var arrayObj = new Array(); //创建一个数组 var arrayObj = new Array([size]); //创建一个数组并指定长 ...

  9. vue非空校验

    效果图 实现代码 //页面html <div> <ul class="listinfo"> <li> <span class=" ...

  10. (GDOI2018模拟九)【UOJ#192】【UR#14】最强跳蚤

    (开头先Orz myh) 原题目: 在人类和跳蚤的战争初期,人们凭借着地理优势占据了上风——即使是最强壮的跳蚤,也无法一下越过那一堵坚固的城墙. 在经历了惨痛的牺牲后,跳蚤国王意识到再这样下去,跳蚤国 ...