sqlserver根据id集合,批量插入。(巧用sqlserver内置函数)
场景如下,传入的id,如1,3,4,88。可以在.net后台处理,但是我更习惯在数据库中操作。
插入数据时可以这样处理,直接贴代码。
CREATE PROCEDURE pro_CategorySave
(
@ids VARCHAR(400) ,
@type INT ,
@TemplateID INT ,
@CategoryID INT )
AS
BEGIN
DECLARE @str VARCHAR(8000) ;
DELETE FROM GaituApp.dbo.TemplateRelationship
WHERE TemplateID = @TemplateID
AND Type = @type
AND CategoryID = @CategoryID
--判断ids是否为空,为空则不插入
IF ( @ids <> '' )
BEGIN
SET @str = 'INSERT INTO GaituApp.dbo.TemplateRelationship
( TemplateID ,
Type ,
CategoryID ,
CreateTime,
Pid
)
SELECT ' + CAST(@TemplateID AS VARCHAR(20)) + ','
+ CAST(@type AS VARCHAR(20)) + ','
+ CAST(@CategoryID AS VARCHAR(20)) + ',GETDATE(),'
+ REPLACE(@ids, ',',
' union select '
+ CAST(@TemplateID AS VARCHAR(20)) + ','
+ CAST(@type AS VARCHAR(20)) + ','
+ CAST(@CategoryID AS VARCHAR(20))
+ ',GETDATE(),') --PRINT @str EXEC (@str)
END
END
思路就是利用sqlserver自带的replace方法将分隔符替换成union select.具体情况具体分析。
技巧二:sqlserver“数组”使用。
在sqlserver中执行批量操作时,可同时处理多个数据,由于sql不支持数组,可以变向处理,如下:
1.利用replace,直接贴代码,
CREATE TABLE #temp
(
STR VARCHAR(20) NOT NULL
)
DECLARE @str VARCHAR(200)
DECLARE @result VARCHAR(1000)
SET @str='a,b,c,d,e,f,g'
SET @result='INSERT INTO #temp
( STR ) select '''+REPLACE(@str,',',''' union select ''')+''''
PRINT @result
EXEC(@result)
SELECT * FROM #temp
DROP TABLE #temp --print result
INSERT INTO #temp
( STR ) select 'a' union select 'b' union select 'c' union select 'd' union select 'e' union select 'f' union select 'g'
2.利用charindex结合substring。
charindex用法,charindex('要查找的分隔符','字符串',int_length),
substring用法,substring('字符串',int_start,int_length).贴代码咯,详细代码注释放在程序段了
CREATE TABLE #temp
(
strcolumn VARCHAR(20)
)
DECLARE @str VARCHAR(200);
--当前的字符串索引
DECLARE @currPostion INT;
--当前的分割符索引
DECLARE @currSplit INT;
SET @str='i,love,you,lover';
--初始化,索引都为1,数据库函数中,索引都是以1开始。
SET @currPostion=1;
SET @currSplit=1;
WHILE @currPostion<LEN(@str)
BEGIN
SET @currSplit=CHARINDEX(',',@str,@currPostion);
IF @currSplit>@currPostion
BEGIN
INSERT INTO #temp
( strcolumn )
SELECT SUBSTRING(@str,@currPostion,@currSplit-@currPostion);
END
ELSE
BEGIN
INSERT INTO #temp
( strcolumn )
SELECT SUBSTRING(@str,@currPostion,LEN(@str)-@currPostion+1);
BREAK;
END
SET @currPostion=@currSplit+1;
END
SELECT * FROM #temp
DROP TABLE #temp
下面贴个利用charindex,substring获取数组长度的函数。注释在代码中。
CREATE FUNCTION [dbo].[returnArryLength]
(
@str VARCHAR(5000) ,
@split VARCHAR(10)
)
RETURNS INT
AS
BEGIN
--当前字符起始位置
DECLARE @curr_position INT ;
--当前分隔符位置
DECLARE @curr_split INT ;
DECLARE @count INT ;
SET @curr_position = 1 ;
SET @curr_split = 1 ;
SET @str = LTRIM(RTRIM(@str)) ;
IF LEN(@str) = 0
BEGIN
RETURN 0 ;
END
ELSE
BEGIN
SET @count=1;
SET @curr_split=CHARINDEX(@split,@str,@curr_position)
WHILE @curr_split<>0
BEGIN
SET @count=@count+1;
SET @curr_position=@curr_split+1;
SET @curr_split=CHARINDEX(@split,@str,@curr_position);
END
END
RETURN @count ;
END
然后是利用charindex,substring根据索引返回元素的函数。注释在代码中。
CREATE FUNCTION [dbo].[getArryElementByIndex]
(
@str varchar(5000),
@split varchar(20),
@index INT--根据索引查询元素
)
RETURNS VARCHAR(500)
AS
BEGIN
--a,b,c,d,e
SET @str=LTRIM(RTRIM(@str));
DECLARE @loopcount INT;
DECLARE @i INT;
DECLARE @returnElement VARCHAR(50);
--分割符索引
DECLARE @curr_split INT;
--当前字符索引
DECLARE @curr_positon INT;
--设置循环次数
SET @loopcount=@index;
SET @i=1;
SET @curr_split=1;
SET @curr_positon=1;
WHILE @i<=@loopcount
BEGIN
SET @curr_split=CHARINDEX(@split,@str,@curr_positon);
IF @curr_split<>0
BEGIN
SET @returnElement=SUBSTRING(@str,@curr_positon,@curr_split-@curr_positon)
END
ELSE
BEGIN
SET @returnElement=SUBSTRING(@str,@curr_positon,LEN(@str)-@curr_positon+1)
END
SET @curr_positon=@curr_split+1;
SET @i=@i+1;
END
RETURN @returnElement;
END
返回数组元素的函数
sqlserver根据id集合,批量插入。(巧用sqlserver内置函数)的更多相关文章
- 【转载】C#批量插入数据到Sqlserver中的三种方式
引用:https://m.jb51.net/show/99543 这篇文章主要为大家详细介绍了C#批量插入数据到Sqlserver中的三种方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本篇, ...
- python_way,day3 集合、函数、三元运算、lambda、python的内置函数、字符转换、文件处理
python_way,day3 一.集合 二.函数 三.三元运算 四.lambda 五.python的内置函数 六.字符转换 七.文件处理 一.集合: 1.集合的特性: 特性:无序,不重复的序列 如果 ...
- Python 第三篇(下):collections系列、集合(set)、单双队列、深浅copy、内置函数
一.collections系列: collections其实是python的标准库,也就是python的一个内置模块,因此使用之前导入一下collections模块即可,collections在py ...
- pathon 基础学习-集合(set),单双队列,深浅copy,内置函数
一.collections系列: collections其实是python的标准库,也就是python的一个内置模块,因此使用之前导入一下collections模块即可,collections在pyt ...
- 跟着ALEX 学python day3集合 文件操作 函数和函数式编程 内置函数
声明 : 文档内容学习于 http://www.cnblogs.com/xiaozhiqi/ 一. 集合 集合是一个无序的,不重复的数据组合,主要作用如下 1.去重 把一个列表变成集合 ,就自动去重 ...
- 拷贝,集合,函数,enumerate,内置函数
1.拷贝 字符串和数字.赋值 id一样 import copy #提供拷贝功能 copy.copy() #原来的和现在的一起修改,不用修改时用浅copy,节省内存,复制最外层 copy.deepcop ...
- Python数据类型的内置函数之tuple(元组),dict(字典),set(集合)
Python数据类型内置函数 - str(字符串) - list(列表) - tuple(元组) - dict(字典) - set(收集) tuple(元组)的操作 - (count)统计元组中元素出 ...
- sqlserver学习笔记(六)—— sqlserver内置函数(字符串、日期)
sqlserver中有很多内置函数,这里总结了一些常用的 一.关于字符串的函数: 1.CHARINDEX 寻找一个指定字符串在另一个字符串中的起始位置 SELECT CHARINDEX('world‘ ...
- [SQL]SUTFF内置函数的用法 (删除指定长度的字符并在指定的起始点插入另一组字符)
STUFF 删除指定长度的字符并在指定的起始点插入另一组字符. 语法 STUFF ( character_expression , start , length , character_express ...
- 文成小盆友python-num3 集合,函数,-- 部分内置函数
本接主要内容: set -- 集合数据类型 函数 自定义函数 部分内置函数 一.set 集合数据类型 set集合,是一个无序且不重复的元素集合 集合基本特性 无序 不重复 创建集合 #!/bin/en ...
随机推荐
- Centos6.3 jekyll环境安装
yum install ruby yum install rubygems yum install ruby-devel gem install rdiscount yum install pytho ...
- 简谈 JavaScript、Java 中链式方法调用大致实现原理
相信,在 JavaScript .C# 中都见过不少链式方法调用,那么,其中实现该类链式调用原理,大家有没有仔细思考过?其中 JavaScript 类库:jQuery 中就存在大量例子,而在 C# 中 ...
- java读取properties的工具类PropertiesUtil
package org.properties.util; import java.io.FileInputStream; import java.io.FileOutputStream; import ...
- JS基础DOM篇之二:DOM级别与节点层次?
通过上一篇我们大致了解了什么是DOM,今天我们继续深入了解. 1.DOM级别 在大家阅读DOM标准的时候,可能会看到DOM(0/1/2/3)级的字眼,这就是DOM级别.但实际上,DOM0级 ...
- 【转】Android真机抓屏- Android Screen Monitor
http://www.cnblogs.com/xiaofeixiang/p/4086092.html 一般运行Android应用程序有两种方式一种是设置Android虚拟设备模拟器,通过Android ...
- QM课程02-外部功能
质量计划 · 对质量计划和检验计划进行基本数据的管理 · 物料说明 · 检验计划 质量检验 · 触发检验 · 具有检验计划选择和样本计算的检验处理 · 打印采样和检验的车间文档 · 记录结果和缺陷 · ...
- Android Camera
Android调用系统api使用照相机功能,实现拍照获取图片以及从照相机库中获取指定图片的功能. 下面是演示样例代码: <?xml version="1.0" encodin ...
- 安卓模拟器BlueStacks 安装使用教程(图解)
系统要求 操作系统 Win XP SP3/Vista/Win 7/Win 8/Win 8.1 所需的运行环境 Win XP用户请先升级到SP3 并安装Windows Installer 4.5 Win ...
- ural 1998 The old Padawan
先预处理每一个点往前退几步 就一个trick..要处理这一秒已经超出了要拿完所花的时间 #include <iostream> #include <cstring> #incl ...
- MapReduce数据连接
对于不同文件里的数据,有时候有相应关系,须要进行连接(join),获得一个新的文件以便进行分析.比方有两个输入文件a.txt,b.txt,当中的数据格式分别例如以下 1 a 2 b 3 c 4 d 1 ...