SQL批量更新操作[转载]

SQL批量更新操作[转载]

之前有提過一個方式來批量更新DB的資料,就是利用分隔符號把所有資料合併成單一字串,然後傳送此字串給SQL Server去轉換成表格做進階運用,今天就來看一下該如何利用此方式。

首先建立一個方法(Method)把要批量更新的資料組合成一個字串,你可以建立屬於自己的方法,這邊我用下面的範例說明。

0
1
SQL批量更新操作[转载]
public
static
string JoinList<T>(
string delimiter, IEnumerable<T> items, Converter<T,
string> converter)


0
2
SQL批量更新操作[转载]
SQL批量更新操作[转载]

{

03 SQL批量更新操作[转载]    StringBuilder builder = new StringBuilder();
04 SQL批量更新操作[转载]    foreach (T item in items)
05 SQL批量更新操作[转载]SQL批量更新操作[转载]    {

06 SQL批量更新操作[转载]        builder.Append(converter(item));
07 SQL批量更新操作[转载]        builder.Append(delimiter);
08 SQL批量更新操作[转载]    }

09 SQL批量更新操作[转载]    if (builder.Length > 0)
10 SQL批量更新操作[转载]        builder.Length = builder.Length – delimiter.Length;
11 SQL批量更新操作[转载]
12     return builder.ToString();
13 SQL批量更新操作[转载]}

此方法可以接受不同的資料型態然後轉成字串輸出,其使用方法如下:

List<
int> lstCustomerID =
new List<
int> { 1001, 1002, 1003, 1004 };


//使用”,”作為分隔字元,輸入的資料型態為int


SQL批量更新操作[转载]
string strParameter = JoinList<
int>(
“,”, lstCustomerID,
delegate(
int item)

{ return item.ToString(); });

幫然也可以輸入其他的資料型態如下

//一樣建立一個List<Guid>物件


SQL批量更新操作[转载]List<Guid> lstCustomerID =
new List<Guid>

{ guid1, guid2, … };


//使用”,”作為分隔字元,輸入的資料型態為Guid


SQL批量更新操作[转载]
string strParameter = JoinList<Guid>(
“,”, lstCustomerID,
delegate(Guid item)

{ return item.ToString(); });

此字串內容會是這樣

1001,1002,1003,1004

將此字串送入後端的SQL資料庫後,資料庫需要有function把此字串轉成資料表以利運用,下面是一個範例如何將此類字串轉成table。

0
1
CREATE FUNCTION dbo.fxnParseCommaDelmitedList


0
2 (


0
3 @CommaDelimitedList
varchar(8000)


0
4 )


0
5 RETURNS @TableVar
TABLE (ItemID
int
NOT
NULL )


0
6
AS


0
7
BEGIN


0
8  
DECLARE @IDListPosition
int


0
9  
DECLARE @IDList
varchar(4000)


10  
DECLARE @ArrValue
varchar(4000)


11  
SET @IDList =
COALESCE(@CommaDelimitedList,
)


12  
IF @IDList <>



13  
BEGIN


14  
–先在字串最後補上一個’,’


15  
SET @IDList = @IDList +
‘,’


16  
WHILE
PATINDEX(
‘%,%’ , @IDList ) <> 0


17      
BEGIN


18    
SELECT @IDListPosition =
PATINDEX(
‘%,%’ , @IDList)


19    
SELECT @ArrValue =
LEFT(@IDList, @IDListPosition – 1)


20    
–將分割後的數值存入@TableVar


21    
INSERT
INTO @TableVar (ItemID)
VALUES (
CONVERT(
int, @ArrValue))


22    
–將已經處理過的字串移除


23    
SELECT @IDList =
STUFF(@IDList, 1, @IDListPosition,
)


24      
END


25  
END


26  
RETURN


27
END

建立上面這個function並放在Table-Valued的資料夾下即可。

使用方式:

Select *


From dbo.fxnParseCommaDelmitedList(@parameter)

就會得到如下的表格

ItemID
1001
1002
1003
1004

原文:
http://www.dotblogs.com.tw/kennyshu/archive/2009/07/12/9449.aspx

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/110690.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • phpstome2021.5.1 激活码(最新序列号破解)[通俗易懂]

    phpstome2021.5.1 激活码(最新序列号破解),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月20日
    44
  • 磁珠的作用

    磁珠的作用磁珠的作用在成品电路板上,我们会看到一些导线或元件的引脚上套有黑色的小磁环,这就是本文要介绍的磁珠。磁珠的全称为铁氧体磁珠滤波器(另有一种是非晶合金磁性材料制作的磁珠),是一种抗干扰元件,滤除高频噪声

    2022年8月5日
    5
  • 8.app后端和web后端的区别

    8.app后端和web后端的区别很多从web后端转到app后端的小伙伴经常很茫然,不知道这两者之间有啥区别。本文通过例子,分析web后端和app后端的区别,使各位更好地把握app后端的架构。

    2022年6月22日
    57
  • OpenGL的glPushMatrix和glPopMatrix矩阵栈顶操作函数详解

    OpenGL中图形绘制后,往往需要一系列的变换来达到用户的目的,而这种变换实现的原理是又通过矩阵进行操作的。opengl中的变换一般包括视图变换、模型变换、投影变换等,在每次变换后,opengl将会呈现一种新的状态(这也就是我们为什么会成其为状态机)。有时候在经过一些变换后我们想回到原来的状态,就像我们谈恋爱一样,换来换去还是感觉初恋好,怎么办?强大的openg…

    2022年4月9日
    51
  • mse均方误差计算公式_视觉SLAM十四讲实践之真实轨迹和估计轨迹均方根误差「建议收藏」

    mse均方误差计算公式_视觉SLAM十四讲实践之真实轨迹和估计轨迹均方根误差「建议收藏」为了理解RMSE首先介绍一些统计学的概念,然后介绍SLAM领域里面的计算精度ATE和RPE的用法。中位数一组数据按大小顺序排列,位于最中间的一个数据(当有偶数个数据时,为最中间两个数据的平均数)叫做这组数据的中位数。用中位数作为一组数据的代表,可靠性不高,但受极端数据影响的可能性小一些,有利于表达这组数据的“集中趋势”。众数几组数据中出现次数最多的那个数据,叫做这批数据的众数。用众…

    2022年9月30日
    3
  • ac测评题库_ftb任务指令

    ac测评题库_ftb任务指令有两台机器 A,B 以及 K 个任务。机器 A 有 N 种不同的模式(模式 0∼N−1),机器 B 有 M 种不同的模式(模式 0∼M−1)。两台机器最开始都处于模式 0。每个任务既可以在 A 上执行,也可以在 B 上执行。对于每个任务 i,给定两个整数 a[i] 和 b[i],表示如果该任务在 A 上执行,需要设置模式为 a[i],如果在 B 上执行,需要模式为 b[i]。任务可以以任意顺序被执行,但每台机器转换一次模式就要重启一次。求怎样分配任务并合理安排顺序,能使机器重启次数最少。输入格

    2022年8月9日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号