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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 注册境外邮箱有哪些_腾讯会员邮箱登录

    注册境外邮箱有哪些_腾讯会员邮箱登录TOMVIP邮箱可在客户端绑定,支持多个终端邮件同步。163VIP邮箱超大容量、邮件群发效果好、微信邮件实时提醒,企业版邮箱也可以使用误删恢复功能。

  • 微信公众号开发者账号_小程序后端开发教程

    微信公众号开发者账号_小程序后端开发教程编辑模式与开发模式微信公众帐号申请成功后,要想接收处理用户的请求,就必须要在“高级功能”里进行配置,点击“高级功能”,将看到如下界面:从上图中可以看到,高级功能包含两种模式:编辑模式和开发模式,并且这两种模式是互斥关系,即两种模式不能同时开启。那两种模式有什么区别呢?作为开发人员到底要开启哪一种呢?编辑模式:主要针对非编程人员及信息发布类公众帐号使用。开启该模式后,可以方便地通

  • ArtCAM+Powermill雕刻编程加工视频教程 浮雕 玉石「建议收藏」

    ArtCAM+Powermill雕刻编程加工视频教程 浮雕 玉石「建议收藏」ArtCAM+Powermill雕刻编程加工视频教程浮雕玉石四轴雕刻链接:https://pan.baidu.com/s/1gyrg7kYYBFHzTBK9ue0G1Q提取码:67kb

  • prototype.js学习(1)

    prototype.js学习(1) 1、关于javascript的apply和call函数prototype.js中用了大量的apply和call函数,不注意会造成理解偏差。官方解释:应用某一对象的一个方法,用另一个对象替换当前对象。apply与call的区别是第二个参数不同。apply是 数组或者arguments对象。而call是逗号隔开的任何类型。apply,call方法最让人混淆的地方也是apply,call的

  • ECLIPSE软件安装MyBatis插件 MyBatis Generator

    ECLIPSE软件安装MyBatis插件 MyBatis GeneratorECLIPSE软件安装MyBatis插件打开Eclipse->导航栏Help->EclipseMarketplace会出现如下页面:搜索mybatis->安装我红框框的东西安装就是同意安装,然后install之类的…安装好之后会提示重启Eclipse…

  • java贪吃蛇源码

    java贪吃蛇源码java是一种面向对象的语言,有着其中不用质疑的优点。学习java将近三个月了,一直在琢磨着“万物皆对象”的意义,却总是只知其表不知其意,做完这个java贪吃蛇后才有了那么一点的理解。直接上效果图。游戏分为了六个类,分别为:Node类:蛇身都是由一个一个节点组成,所以首先将节点抽象为一个类。Snake类:此类是一条蛇抽象出来的一个类。一种包含了存储节点的LinkedList类型…

发表回复

您的电子邮箱地址不会被公开。

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