sql 针对多个id或名称的分割和组合
开发中经常遇到把多个id拼接在一起符号隔开传入数据库,那拆分呢就是个大事
SELECT nPushID
INTO #temp
FROM Table1
WHERE CHARINDEX( ',' + CONVERT(VARCHAR(10), nCoulmn) + ',', ',' + '3305,3311,3314' + ',') > 0
SELECT * FROM #temp
这里需要有表,并且是有存在数据与传的字符串相关。列针对的是int 型,所以要转换。
DECLARE
@a decimal(18, 2) = 360, --返券的金额
@b decimal(18, 2) = 5, --券张
@c VARCHAR(50)= '40,30,10,10,10',
@cResult DECIMAL(18,2) = 0,
@cRemainder DECIMAL(18,2) = 0, --余额
@ignore DECIMAL(18,2) = 70, --余额标准,不足标准将余额合并到最后一张分券
@str varchar(8000)
if object_id(N'tempdb..#temp1',N'U') is not null
begin
drop table #temp1
print 'aaa'
end
create table #temp1 (
id int,
dmPrice DECIMAL(18,2)
)
set @str = 'select dmPrice='+replace(@c,',',''+' union all select ')+'' --set @str = 'select dmPrice='''+replace(@c,',',''''+' union all select ''')+'''' --字符串列 set @str='select id=identity(int,1,1),dmPrice into #temp from ('+@str+') a ;
insert into #temp1 select * from #temp;'
exec(@str) --可针对临时表做操作
INSERT INTO Table_a SELECT '','',10,1,dmPrice,GETDATE(),10,10 FROM #temp1 DECLARE
@c VARCHAR(50)= '40,30,10,10,10',
@str VARCHAR(8000)=''
set @str = 'select name='''+replace(@c,',',''''+' union all select ''')+'''' set @str='select id=identity(int,1,1),name into #temp from ('+@str+') a '
exec(@str) --这种只能用作显示,且无法针对临时表做操作
这个就不需要真实的表和数据来做分割。网上有很多循环的例子,但效率不如这个
针对订单那种订单主从表,从表多个的名称拼接在一起的
--实例1 分割符在前
select isnull ((select '@'+ CommodityName from OrderInfo where OrderInfo.orderid =OrderMain.OrderID for xml path('')),'') from OrderMain
where orderid ='' --针对分隔符在前,可以用stuff很方便
select isnull (stuff((select '@'+ CommodityName from OrderInfo where OrderInfo.orderid =OrderMain.OrderID for xml path('')),1,1,''),'') from OrderMain
where orderid ='' --实例2 同表,
select stuff((select ','+CONVERT(VARCHAR(20),A.nID) from Table_a A WHERE A.nId= @nId FOR xml PATH('')), 1, 1, '') as nID
--分隔符在后,对于拼接名称的,个人觉得用substring、left还麻烦点,不如在后台或者前台去处理
--写入临时表的方式分割
DECLARE
@str1 NVARCHAR(max),
@nTempF VARCHAR(MAX)='a;b;c;d;e;f;g' create table #tt(nID int,aa VARCHAR(MAX))
insert into #tt values(3,@nTempF) SELECT a.vcNewID,T.c.value('.', 'sysname') AS vcWxID
into #temp1
FROM (select NEWID() as vcNewID ,CONVERT(XML,'<x>'+REPLACE(aa,';','</x><x>')+'</x>') vcSerialNo from #tt) AS A
CROSS APPLY A.vcSerialNo.nodes('/x/text()') T(c) select * from #temp1
sql 2016 将支持OpenJson
declare @vcLoginIdJson nvarchar(max)
set @vcLoginIdJson = '{"admin":"","hyh":""}'
select [key] as vcLoginId FROM openjson(@vcLoginIdJson)
详细参考地址
https://docs.microsoft.com/zh-cn/sql/relational-databases/json/convert-json-data-to-rows-and-columns-with-openjson-sql-server
sql 针对多个id或名称的分割和组合的更多相关文章
- sql 查询表中所有字段的名称
最近工作用到SQL语句查询表中所有字段的名称,网上查询,发现不同数据库的查询方法不同,例如: SQL server 查询表的所有字段名称:Select name from syscolumns Whe ...
- SQL-29 使用join查询方式找出没有分类的电影id以及名称
题目描述 film表 字段 说明 film_id 电影id title 电影名称 description 电影描述信息 CREATE TABLE IF NOT EXISTS film ( film_i ...
- PowerDesigner PDM生成sql脚本时:表的名称和表里面的字段名称都有引号解决。。。
PowerDesigner PDM生成sql脚本时:表的名称和表里面的字段名称都有引号解决... 1.当你的PowerDesigner 是新安装时,你得设置可能就会出现一些问题,在这里比如:PDM生成 ...
- SQL 查询某字段id为空(不为空)
1 sql 查询某字段id为空 select * from 表名 where id is null ; 2 sql 查询某字段id不为空 select * from 表名 wher ...
- 获取设备 ID 和名称
获取设备 ID 和名称 .NET Framework 3.5 其他版本 更新:2007 年 11 月 要获取设备的名称,请使用 Dns.GetHostName 属性.通常情况下,默认名称为“P ...
- 简单实用SQL脚本Part:查找SQL Server 自增ID值不连续记录
原文:简单实用SQL脚本Part:查找SQL Server 自增ID值不连续记录 在很多的时候,我们会在数据库的表中设置一个字段:ID,这个ID是一个IDENTITY,也就是说这是一个自增ID.当并发 ...
- 【java/oralce/sql】往一张仅有id,名称,创建时间三个字段的表中插入百万数据需要多久?1分26秒
代码下载:https://files.cnblogs.com/files/xiandedanteng/fastfilltable20191222.rar 表testtb18的结构如下: CREATE ...
- 如何用sql批量删除一个id段内的dedecms文章?
之前因为ytkah批量添加了dedecms文章,数量有些多,后面出现问题了,想要删除一部分织梦文章,后台一篇篇删,删到手软(相关内容:修改dedecms关键词到手软),于是就想到了sql数据库操作!那 ...
- MS SQL 多连接数时修改数据库名称
在MS SQL中,如果你想修改某一个数据库的名称,你可以通过下面几种方法实现. 方法一:使用SP_RENAMEDB系统存储过程实现. 语法: sp_renamedb [ @dbname = ] 'ol ...
随机推荐
- etcd使用之ttl不准确问题
问题现象 部署有一个etcd集群,分别是10.8.65.106,10.8.65.107和10.8.65.108. 然后我使用etcdctl为一个值设置ttl,然后通过watch观察,发现失效时间不准确 ...
- dom4解析xml格式文件实例
以下给4种常见的xml文件的解析方式的分析对比: DOM DOM4J JDOM SAX 解析XML文件的几种方式和区别答: Dom解析 在内存中创建一个DOM树,该结构通常需要加载整个文档然后才能做工 ...
- Android自定义控件系列(一)—Button七十二变
转载请注明出处:http://www.cnblogs.com/landptf/p/6290791.html 忙了一段时间,终于有时间整理整理之前所用到的一些知识,分享给大家,希望给同学们有些帮助,同时 ...
- 【CSS学习笔记】初始化CSS后,写li,并利用背景图片,来完成li小图标的效果,且达到个浏览器兼容
第一种情况 /*当标题前的图标时单独的一个点儿或者方块或者其他类似图标时,定义背景图background要放在<li>里. 在<li>中设置背景图片的尺寸,地址,不重复, ...
- js Checkbox 传递多个值给后台
------前台JS "<input class=\'jTabCheck2\' type=\'checkbox\' partvguid=" + obj + " pr ...
- 干货云集 WOT 2017全球架构与运维技术峰会揭密技术难点
WOT,World Of Tech专注互联网IT技术领域,是一场不容错过的技术盛会!WOT 2017全球架构与运维技术峰会三大章节,15大技术专场,60+国内外一线互联网精英大咖站台,打造兼顾技术视野 ...
- qdoc 写法
Qdoc 注释 Qdoc注释有一些命令, 能够对文档进行组织. QDoc能识别以下3种类型的命令 主题(topic command) 主题命令确定了文档的元素,例如C++类(class),函数(fun ...
- 脚本录制--html模式和url模式
设置位置:tool--recording options-recording 1.html模式--默认---结果较简单 脚本采用html页面的形式来展示,优点:容易维护.容易理解 2.url模式--- ...
- 利用Hibernate监听器实现用户操作日志
网上搜索发现,实现用户操作日志的方式有:自定义注解方式.Hibernate拦截器方式.Hibernate监听器方式等. 1.自定义注解方式较为麻烦,需要进行操作记录的方法均需要添加注解,但是相对的操作 ...
- js splice比较好用的方法
http://www.w3school.com.cn/jsref/jsref_splice.asp从w3c看到这个方法,感觉不错,记录一下.