设为首页 收藏本站
查看: 708|回复: 0

[经验分享] 在SQL SErver中实现数组功能

[复制链接]

尚未签到

发表于 2015-6-30 14:04:34 | 显示全部楼层 |阅读模式
在SQL SErver中实现数组功能
  本文摘自肖桂东编著的《SQL Server 疑难解析》
  问题描述:
    我需要向一个存储过程传递数组类型的参数,可是Transact-SQL里面没有数组类型,请问应该怎样实现数组的功能?
  问题分析:
    SQL Server并没有数组类型,ANSI SQL-92标准中并没有任何有关数组方面的定义。要实现其他高级语言中的数组的功能,我们必须使用一些特殊的处理方法,其中包括特殊设计的字符参数、临时表、XML等。

问题解答:
    第一种方法是使用特殊设计的字符参数来模拟数组。
    我们可以用 varchar 数据类型来模拟一个数组,数组中的元素用逗号分隔开,接着通过WHILE循环使用CHARINDEX以及SUBSTRING函数来提取其中的元素。
    示例代码如下:
CREATE PROCEDURE sum_of_array @list varchar(1000)
AS
DECLARE @ix int, @pos int, @str varchar(1000), @sum int
SET @pos = 1
SET @ix = 1
SET @sum = 0
WHILE @ix > 0
BEGIN
SET @ix = charindex(',', @list, @pos)
IF @ix > 0
SET @str = substring(@list, @pos, @ix - @pos)
ELSE
SET @str = substring(@list, @pos, len(@list))
SET @str = ltrim(rtrim(@str))
SET @sum = @sum + cast(@str AS int)
SET @pos = @ix + 1
END
SELECT @sum
GO
    该示例代码可以求出一个整型数据数组的和,调用方式为:
EXEC sum_of_array @list = '1,2,3,4,5'
    结果为:16。
    第二种方法是利用 WHERE…IN…语句配合特殊设计的字符串来实现数组。
    示例代码如下:
CREATE PROCEDURE query_sysobjects @array nvarchar(1000)
AS
BEGIN
SET NOCOUNT ON
DECLARE @nsql nvarchar(4000)
SET @nsql = '
SELECT *
FROM sysobjects
WHERE name IN (' + @array + ')'
EXEC sp_executesql @nsql
END
GO
    该示例代码可以查询 sysobjects 表中指定对象的信息,对象由调用参数指定。例如我们要查询sysobjects表中sysusers、sysindexes以及syscolumns三个对象的信息,则调用方式为:
EXEC query_sysobjects
@array = '''sysusers'',''sysindexes'',''syscolumns'''
    第三种方法是使用临时表。调用存储过程之前构造一张临时表,将数组的内容逐行存放在表中,把表作为参数传递给存储过程。存储过程将表的内容再次读到一张临时表中,从而得到数组的内容。
    示例代码为:
CREATE PROCEDURE mytest @MyParmTempTable varchar(30)
AS
BEGIN
CREATE TABLE #MyInternalList(list_item varchar(2) NOT NULL)
SET NOCOUNT ON
INSERT #MyInternalList EXEC ('select * from ' + @MyParmTempTable)
SELECT *
FROM sysobjects
WHERE type IN
(
SELECT list_item
FROM #MyInternalList
)
END
GO
    该示例代码同样查询 sysobjects 表,返回所有类型为 S、U 和 P 的对象的信息。调用之前要先构建一个表(也可以为临时表):
CREATE TABLE #MyList(list_item varchar(2) NOT NULL)
INSERT #MyList VALUES ('S')
INSERT #MyList VALUES ('U')
INSERT #MyList VALUES ('P')
GO
    调用的时候只要向存储过程传递这个临时表即可:
EXEC mytest #MyList
GO
    最后,我们还可以使用 XML 来实现。
    示例代码如下:
USE pubs
GO
CREATE PROCEDURE usp_Array
@Array TEXT
AS
DECLARE @XMLDoc INT
EXEC sp_xml_preparedocument @XMLDoc OUTPUT, @Array
SELECT *
FROM OPENXML (@XMLDoc , '/ROOT/Array', 1 )
WITH (Id INT, Value varchar(15)) AS TempArray
INNER JOIN authors ON authors.au_id = TempArray.Value
EXEC sp_xml_removedocument @XMLDoc
GO
    调用的代码为:
DECLARE @doc varchar(500)
SET @doc ='



'
EXEC usp_Array @doc

CHARINDEX:返回字符串中指定表达式的起始位置。
    语法:CHARINDEX ( expression1 , expression2 [ , start_location ] )
参数介绍如下。
    expression1:一个表达式,其中包含要寻找的字符的次序。expression1 是一个短字符数据类型分类的表达式。
    expression2:一个表达式,通常是一个用于搜索指定序列的列。expression2 属于字符串数据类型分类。
    start_location:在expression2 中搜索 expression1 时的起始字符位置。如果没有给定 start_location,而是一个负数或零,则将从 expression2 的起始位置开始搜索。
    返回类型:
int

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-81969-1-1.html 上篇帖子: SQL Server 2005/2008 合并复制Step by Step 下篇帖子: SQL Server Collation介绍及其变更对数据的影响
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表