电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

SQL Server 2008新功能─傳遞表值參數

瀏覽:182日期:2023-11-04 08:23:37

許多人一直希望能夠實現把表格變量傳遞到存儲過程中,如果變量可以被聲明,那么它就應該能夠被傳遞。而最新的SQL Server 2008則有這項功能!想知道如何才能把表格變量(包括內含的數據)傳遞到存儲過程和功能中去嗎?

為什么要傳遞表值參數?

用戶常常會碰到許多需要把數值容器而非單個數值放到存儲過程里的情況。對于大部分的編程語言而言,把容器數據結構傳遞到例程里或傳遞出來是很常見而且很必要的功能。TSQL也不例外。

SQL Server 2000通過OPENXML可以實現這個功能,用戶可以把數據存儲為VARCHAR數據類型然后進行傳遞。到了SQL Server 2005,隨著 XML數據類型以及XQuery的出現,這個功能變得容易一點。但用戶仍然需要對XML數據進行組建和粉碎才能夠使用它,因此這個功能使用起來并不簡單。SQL Server 2008則能夠把表值數據類型傳遞到存儲過程和功能中,從而大大地簡化了編程的工作,因為程序員無需再花心思去組建和解析XML數據了。該功能還可以讓客戶方開發員傳遞客戶方數據表格到數據庫中。

如何傳遞表格參數?

以銷售為例,首先建立一個 my SalesHistory表格,里面包含了產品銷售的信息。寫以下腳本就可以在數據庫里創建你選擇的表格:

IF OBJECT_ID('SalesHistory')>0 DROP TABLE SalesHistory; GO CREATE TABLE [dbo].[SalesHistory] ( [SaleID] [int] IDENTITY(1,1) NOT NULL PRIMARY KEY, [Product] [varchar](10) NULL, [SaleDate] [datetime] NULL, [SalePrice] [money] NULL ) GO

建立表值參數第一步是創建確切的表格類型,這一步非常重要,因為這樣你就可以在數據庫引擎里定義表格的結構,讓你可以在需要的時候在過程代碼里使用該表格。下面的代碼創建 SalesHistoryTableType 表格類型定義:

CREATE TYPE SalesHistoryTableType AS TABLE ( [Product] [varchar](10) NULL, [SaleDate] [datetime] NULL, [SalePrice] [money] NULL ) GO

如果想要查看系統里其他類型的表格類型定義,你可以執行下面這個查詢命令,查看系統目錄:

SELECT * FROM sys.table_types

我們需要定義用來處理表值參數的存儲過程。下面這個程序能夠接受指定SalesHistoryTableType類型的表值參數,并加載到SalesHistory中,表值參數在Product列中的值為“BigScreen”:

CREATE PROCEDURE usp_InsertBigScreenProducts ( @TableVariable SalesHistoryTableType READONLY ) AS BEGIN INSERT INTO SalesHistory ( Product, SaleDate, SalePrice ) SELECT Product, SaleDate, SalePrice FROM @TableVariable WHERE Product = 'BigScreen' END GO

傳遞的表格變量還可以用做任何其他表格的查詢數據。

在傳遞表值變量到程序中時必須使用 READONLY從句。表格變量里的數據不能做修改——除了修改你可以把數據用于任何其他的操作。另外,你也不能把表格變量用做OUTPUT參數——只能用做input參數。

使用自己的新表格變量類型

首先,要聲明一個變量類型SalesHistoryTableType,不需要再一次定義表格結構,因為在創建這個表格類型的時候已經定義過了。

DECLARE @DataTable AS SalesHistoryTableType The following script adds 1,000 records into my @DataTable table variable: DECLARE @i SMALLINT SET @i = 1 WHILE (@i <=1000) BEGIN INSERT INTO @DataTable(Product, SaleDate, SalePrice) VALUES ('Computer', DATEADD(mm, @i, '3/11/1919'), DATEPART(ms, GETDATE()) + (@i + 57)) INSERT INTO @DataTable(Product, SaleDate, SalePrice) VALUES('BigScreen', DATEADD(mm, @i, '3/11/1927'), DATEPART(ms, GETDATE()) + (@i + 13)) INSERT INTO @DataTable(Product, SaleDate, SalePrice) VALUES('PoolTable', DATEADD(mm, @i, '3/11/1908'), DATEPART(ms, GETDATE()) + (@i + 29)) SET @i = @i + 1 END

只要把數據加載到表格變量里,就可以把結構傳遞到存儲過程中。

注意:當表格變量作為參數傳遞后,表格會在存儲在tempdb系統數據庫里,而不是傳遞整個數據集在內存里。因為這樣保證高效處理大批量數據。所有服務器方的表格變量參數傳遞都是通過使用reference調用tempdb中的表格。

EXECUTE usp_InsertBigScreenProducts @TableVariable = @DataTable

想要查詢程序是否和預想效果一樣,可以執行以下查詢來看記錄是否已經插入到 SalesHistory表格中:

SELECT * FROM SalesHistory

總結:

雖然SQL Server 2008的參數傳遞功能的使用還有一些小小的局限性,比如不能修改參數中的數據和把變量用于output,但是它大大提高了程序性能,它可以減少server往返旅程數、利用表格限制并擴展編程在數據庫引擎中的功能。

標簽: Sql Server 數據庫
主站蜘蛛池模板: 包塑软管|金属软管|包塑金属软管-闵彬管业 | 锌合金压铸-铝合金压铸厂-压铸模具-冷挤压-誉格精密压铸 | 伸缩器_伸缩接头_传力接头-巩义市润达管道设备制造有限公司 | 化妆品加工厂-化妆品加工-化妆品代加工-面膜加工-广东欧泉生化科技有限公司 | 蜘蛛车-高空作业平台-升降机-高空作业车租赁-臂式伸缩臂叉装车-登高车出租厂家 - 普雷斯特机械设备(北京)有限公司 | 超声骨密度仪-骨密度检测仪-经颅多普勒-tcd仪_南京科进实业有限公司 | 称重传感器,测力传感器,拉压力传感器,压力变送器,扭矩传感器,南京凯基特电气有限公司 | 武汉高低温试验机-现货恒温恒湿试验箱-高低温湿热交变箱价格-湖北高天试验设备 | 辊道窑炉,辊道窑炉厂家-山东艾希尔| 制氮设备-变压吸附制氮设备-制氧设备-杭州聚贤气体设备制造有限公司 | 多功能三相相位伏安表-变压器短路阻抗测试仪-上海妙定电气 | 亚洲工业智能制造领域专业门户网站 - 亚洲自动化与机器人网 | 开平机_纵剪机厂家_开平机生产厂家|诚信互赢-泰安瑞烨精工机械制造有限公司 | 优宝-汽车润滑脂-轴承润滑脂-高温齿轮润滑油脂厂家 | 磁力反应釜,高压釜,实验室反应釜,高温高压反应釜-威海自控反应釜有限公司 | 早报网 | 板框压滤机-隔膜压滤机-厢式压滤机生产厂家-禹州市君工机械设备有限公司 | 水冷式工业冷水机组_风冷式工业冷水机_水冷螺杆冷冻机组-深圳市普威机械设备有限公司 | 耐高温风管_耐高温软管_食品级软管_吸尘管_钢丝软管_卫生级软管_塑料波纹管-东莞市鑫翔宇软管有限公司 | 送料机_高速冲床送料机_NC伺服滚轮送料机厂家-东莞市久谐自动化设备有限公司 | 欧洲MV日韩MV国产_人妻无码一区二区三区免费_少妇被 到高潮喷出白浆av_精品少妇自慰到喷水AV网站 | 伊卡洛斯软装首页-电动窗帘,别墅窗帘,定制窗帘,江浙沪1000+别墅窗帘案例 | 2025第九届世界无人机大会 | 广西教师资格网-广西教师资格证考试网 | 立刷【微电签pos机】-嘉联支付立刷运营中心 | 温湿度记录纸_圆盘_横河记录纸|霍尼韦尔记录仪-广州汤米斯机电设备有限公司 | 蒸压釜-陶粒板隔墙板蒸压釜-山东鑫泰鑫智能装备有限公司 | 发光字|标识设计|标牌制作|精神堡垒 - 江苏苏通广告有限公司 | 自清洗过滤器-全自动自清洗过反冲洗过滤器 - 中乂(北京)科技有限公司 | 数显水浴恒温振荡器-分液漏斗萃取振荡器-常州市凯航仪器有限公司 | 伺服电机维修、驱动器维修「安川|三菱|松下」伺服维修公司-深圳华创益 | 手表腕表维修保养鉴定售后服务中心网点 - 名表维修保养 | 环讯传媒,永康网络公司,永康网站建设,永康小程序开发制作,永康网站制作,武义网页设计,金华地区网站SEO优化推广 - 永康市环讯电子商务有限公司 | 菏泽知彼网络科技有限公司 | 布袋式除尘器|木工除尘器|螺旋输送机|斗式提升机|刮板输送机|除尘器配件-泊头市德佳环保设备 | 国产频谱分析仪-国产网络分析仪-上海坚融实业有限公司 | 特种阀门-调节阀门-高温熔盐阀-镍合金截止阀-钛阀门-高温阀门-高性能蝶阀-蒙乃尔合金阀门-福建捷斯特阀门制造有限公司 | CNC机加工-数控加工-精密零件加工-ISO认证厂家-鑫创盟 | EDLC超级法拉电容器_LIC锂离子超级电容_超级电容模组_软包单体电容电池_轴向薄膜电力电容器_深圳佳名兴电容有限公司_JMX专注中高端品牌电容生产厂家 | 打包箱房_集成房屋-山东佳一集成房屋有限公司 | 视频直播 -摄影摄像-视频拍摄-直播分发 |