婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 不固定參數的存儲過程實現代碼

不固定參數的存儲過程實現代碼

熱門標簽:陜西電銷外呼系統好用嗎 al智能電話機器人 數字匠心電銷機器人 最新人工智能電銷機器人 沒聽見電話機器人幫你接 銀川高頻外呼回撥系統多少錢 如何做地圖標注圖鋪 成都電話外呼系統一般多少錢 蘭州語音外呼系統運營商
我想此時不妨使用字符串參數來幫助我們解決這種情況,利用字符串分割的方法將一個參數分割成數個參數來解決。下面我們看一個例子:

假設現在給你一個產品信息列表(顯示出各個商品的基本信息),現在我想要根據所選擇商品進行統計(任意選擇幾種),例如統計出價格10,11-20,21-30,31-40,41-50,50以上的商品個有多少個(姑且認為就統計這些)。此時如果使用存儲過程就勢必需要傳入所選商品的id作為參數,但是id個數是不固定的。此時估計會有人這樣寫:
復制代碼 代碼如下:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author: jianxin160
-- Create date: 2010.11.05
-- Description: 統計商品
-- =============================================
ALTER PROCEDURE StatProductInfo
(
@ids VARCHAR(8000)
)
AS
BEGIN
DECLARE @followingTen INT
DECLARE @elevenToTwenty INT
DECLARE @twentyOneToThirty INT
DECLARE @thirtyOneToFourty INT
DECLARE @fourtyOneToFifty INT
DECLARE @fiftyOrMore INT

SELECT @followingTen=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(@ids) AND UnitPrice10

SELECT @elevenToTwenty=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(@ids) AND UnitPrice BETWEEN 11 AND 20

SELECT @twentyOneToThirty=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(@ids) AND UnitPrice BETWEEN 21 AND 30

SELECT @thirtyOneToFourty=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(@ids) AND UnitPrice BETWEEN 31 AND 40

SELECT @fourtyOneToFifty=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(@ids) AND UnitPrice BETWEEN 41 AND 50

SELECT @fiftyOrMore=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(@ids) AND UnitPrice>50

SELECT @followingTen AS '$10',@elevenToTwenty AS '$11-$20',
@twentyOneToThirty AS '$21-$30',@thirtyOneToFourty AS '$31-$40',
@fourtyOneToFifty AS '$41-$50',@fiftyOrMore AS '>$50'
END
GO

其實如果你測試一下(例如:EXEC dbo . StatProductInfo '3,4,8,10,22' )是有問題的,sql server認為這整個是一個參數,轉換時出錯。此時我們想一下如果這些字段在一個虛表中就容易操作多了,但是一般虛表是有其他表通過查詢得到,現在根本無法查詢又哪來的虛表呢?聰明的朋友或許已經想到可以使用"表值函數"。對,答案就是使用"表值函數"。我們知道"表值函數"可以返回一個"Table"類型的變量(相當于一張虛表,存放于內存中),我們首先將字符串分割存放到"表值函數"的一個字段中,然后我們再從"表值函數"中查詢就可以了(這個例子也是"表值函數"的一個典型應用)。具體sql如下:
復制代碼 代碼如下:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author: cmj
-- Create date: 2010.11.05
-- Description: 返回一個Table,只有一列,每一行的數據就是分割好的字符串
-- =============================================
CREATE FUNCTION GetSplitFieldsByString
(
@toSplitString varchar(1000),
@splitChar varchar(10)
)
RETURNS
@tb TABLE(sp varchar(100))
AS
BEGIN
DECLARE @i INT
SET @toSplitString=RTRIM(LTRIM(@toSplitString))
SET @i=CHARINDEX(@splitChar,@toSplitString)
WHILE @i>0
BEGIN
INSERT @tb VALUES(LEFT(@toSplitString,@i-1))
SET @toSplitString=RIGHT(@toSplitString,LEN(@toSplitString)-@i)
SET @i=CHARINDEX(@splitChar,@toSplitString)
END
IF LEN(@toSplitString)>0
INSERT @tb VALUES(@toSplitString)
RETURN
END
GO

然后我們稍微修改一下存儲過程:
復制代碼 代碼如下:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author: jianxin160
-- Create date: 2010.11.05
-- Description: 統計商品
-- =============================================
ALTER PROCEDURE StatProductInfo
(
@ids VARCHAR(8000)
)
AS
BEGIN
DECLARE @followingTen INT
DECLARE @elevenToTwenty INT
DECLARE @twentyOneToThirty INT
DECLARE @thirtyOneToFourty INT
DECLARE @fourtyOneToFifty INT
DECLARE @fiftyOrMore INT

SELECT @followingTen=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(SELECT sp FROM dbo.GetSplitFieldsByString(@ids,',')) AND UnitPrice10

SELECT @elevenToTwenty=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(SELECT sp FROM dbo.GetSplitFieldsByString(@ids,',')) AND UnitPrice BETWEEN 11 AND 20

SELECT @twentyOneToThirty=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(SELECT sp FROM dbo.GetSplitFieldsByString(@ids,',')) AND UnitPrice BETWEEN 21 AND 30

SELECT @thirtyOneToFourty=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(SELECT sp FROM dbo.GetSplitFieldsByString(@ids,',')) AND UnitPrice BETWEEN 31 AND 40

SELECT @fourtyOneToFifty=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(SELECT sp FROM dbo.GetSplitFieldsByString(@ids,',')) AND UnitPrice BETWEEN 41 AND 50

SELECT @fiftyOrMore=COUNT(*)
FROM dbo.Products
WHERE ProductID IN(SELECT sp FROM dbo.GetSplitFieldsByString(@ids,',')) AND UnitPrice>50

SELECT @followingTen AS '$10',@elevenToTwenty AS '$11-$20',@twentyOneToThirty AS '$21-$30',
@thirtyOneToFourty AS '$31-$40',@fourtyOneToFifty AS '$41-$50',@fiftyOrMore AS '>$50'
END
GO

這樣通過執行EXEC dbo . StatProductInfo '3,4,8,10,22' 就可以得到想要的結果了:

試試這樣會不會快一些
復制代碼 代碼如下:

SELECT SUM(CASE WHEN UnitPrice 10 THEN 1 ELSE 0 END) '$10',
SUM(CASE WHEN UnitPrice BETWEEN 11 AND 20 THEN 1 ELSE 0 END) '$11-$20',
SUM(CASE WHEN UnitPrice BETWEEN 21 AND 30 THEN 1 ELSE 0 END) '$21-$30',
...
SUM(CASE WHEN UnitPrice > 50 THEN 1 ELSE 0 END) '>$10'
FROM dbo.Products
WHERE ProductID IN(SELECT sp FROM dbo.GetSplitFieldsByString(@ids,','))

標簽:本溪 朔州 宜春 邢臺 遼源 鹽城 通化 巴彥淖爾

巨人網絡通訊聲明:本文標題《不固定參數的存儲過程實現代碼》,本文關鍵詞  不,固定,參數,的,存儲,過程,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《不固定參數的存儲過程實現代碼》相關的同類信息!
  • 本頁收集關于不固定參數的存儲過程實現代碼的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美丰满少妇xxxxx高潮对白| 久久99精品视频| 久久久精品天堂| 日韩欧美一级二级| 欧美精品v国产精品v日韩精品| 一本久道久久综合中文字幕 | 欧美午夜电影一区| 91首页免费视频| 一本色道亚洲精品aⅴ| 91小视频在线免费看| k8久久久一区二区三区| 色综合久久中文综合久久牛| 在线免费观看视频一区| 91黄色免费网站| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲四区在线观看| 亚洲欧美日韩中文字幕一区二区三区 | 精品久久久久久无| 国产亚洲一区二区在线观看| 中文字幕免费不卡| 亚洲欧美日本韩国| 丝袜亚洲另类欧美综合| 黄一区二区三区| 福利91精品一区二区三区| a美女胸又www黄视频久久| 欧洲在线/亚洲| 日韩一区二区免费高清| 欧美精品一区二区三区久久久| 久久精品综合网| 夜夜嗨av一区二区三区四季av| 天堂一区二区在线免费观看| 精品亚洲国内自在自线福利| 不卡一区二区中文字幕| 欧美在线观看视频一区二区| 欧美精品一区二区久久婷婷| 国产精品久久久99| 日本不卡一区二区三区| 国产成人在线色| 欧美日韩一区二区三区四区| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲同性同志一二三专区| 免费日韩伦理电影| 色综合久久中文字幕综合网| 亚洲精品在线观看网站| 亚洲综合激情另类小说区| 99久久精品免费看国产| 欧美精选一区二区| 亚洲欧美日本在线| 国产一区三区三区| 欧美日韩精品福利| 国产精品久久久久久久久快鸭 | 日韩欧美国产电影| 亚洲日本免费电影| 国产黄人亚洲片| 日韩视频在线一区二区| 亚洲精品福利视频网站| 国产精品欧美一级免费| 久久免费国产精品| 偷窥少妇高潮呻吟av久久免费| 国产黄色成人av| 欧美成人一级视频| 日韩中文字幕1| 91成人在线精品| 亚洲欧洲日韩av| 国产成人免费9x9x人网站视频| 69久久99精品久久久久婷婷| 亚洲欧洲综合另类在线| 国产精品12区| 26uuuu精品一区二区| 天堂成人免费av电影一区| 99麻豆久久久国产精品免费 | 国产精品久久久久影院色老大 | 日韩三级免费观看| 国产一区二区三区蝌蚪| 亚洲视频你懂的| 欧美一区二区三区影视| 成人丝袜18视频在线观看| 亚洲一卡二卡三卡四卡| 久久久不卡影院| 欧美日韩一区二区在线视频| 国产成人av电影免费在线观看| 亚洲一区二区视频在线观看| 久久免费美女视频| 一区二区三区久久久| 日韩午夜激情免费电影| 在线观看一区日韩| 国产成人精品亚洲777人妖 | 精品国产91乱码一区二区三区 | 自拍av一区二区三区| 97国产一区二区| 亚洲激情五月婷婷| 欧美色男人天堂| 日本不卡在线视频| 久久综合九色综合欧美98 | 日韩国产欧美一区二区三区| 欧美一区二区三区日韩| 国产一区二区三区在线观看免费视频 | 亚洲人成在线观看一区二区| 欧美性大战xxxxx久久久| 日韩精品每日更新| 精品国产一区二区三区不卡 | 色综合久久六月婷婷中文字幕| 亚洲高清不卡在线观看| 日韩精品一区二区三区视频| 国产成人av网站| 午夜视频在线观看一区二区三区| 日韩欧美精品在线| 国产99久久久精品| 丝袜脚交一区二区| 国产精品麻豆久久久| 欧美欧美欧美欧美| 不卡视频一二三| 美女视频黄 久久| 综合网在线视频| 日韩欧美亚洲一区二区| 成人在线综合网| 亚洲第一成人在线| 欧美经典一区二区| 欧美一区二区三区婷婷月色| 成人午夜免费视频| 亚洲成av人片一区二区梦乃 | 亚洲一二三专区| 国产精品免费av| 337p日本欧洲亚洲大胆精品| 欧美又粗又大又爽| 国产电影一区二区三区| 免费高清在线一区| 亚洲一区二区三区美女| 国产精品你懂的在线欣赏| 亚洲精品视频自拍| 国产日本欧洲亚洲| 欧美r级在线观看| 欧美日韩国产免费一区二区 | 国产精品一区专区| 青娱乐精品视频在线| 一区二区三区 在线观看视频| 久久久久国产精品麻豆ai换脸| 欧美日韩中字一区| 91亚洲大成网污www| 成人午夜激情影院| 国产福利视频一区二区三区| 美女网站一区二区| 日本不卡不码高清免费观看| 日韩精品福利网| 午夜精品一区二区三区电影天堂| 最近中文字幕一区二区三区| 国产欧美一区二区精品婷婷| 久久蜜桃av一区二区天堂| 精品国产露脸精彩对白 | 一本久道久久综合中文字幕| 不卡的电影网站| caoporn国产精品| 91蜜桃视频在线| 91免费版在线| 一本到三区不卡视频| 91色九色蝌蚪| 欧美婷婷六月丁香综合色| 欧美日韩国产一级| 日韩一区二区三区电影在线观看 | 色哟哟日韩精品| 在线观看国产精品网站| 欧美视频精品在线观看| 欧美欧美午夜aⅴ在线观看| 7777精品伊人久久久大香线蕉的 | 亚洲精品美腿丝袜| 亚洲国产日日夜夜| 青青草97国产精品免费观看 | 亚洲欧美色综合| 亚洲一区二区三区免费视频| 日日夜夜免费精品| 黄色日韩网站视频| av男人天堂一区| 在线观看av一区二区| 日韩三级免费观看| 国产精品久久久久久久蜜臀| 一区二区三区91| 色久优优欧美色久优优| 琪琪一区二区三区| 色婷婷久久久亚洲一区二区三区| 国产色综合一区| 韩国av一区二区三区四区| 国产一区二区在线看| 久久精品999| 99精品在线免费| 欧美一区二区精品久久911| 国产欧美精品区一区二区三区 | 亚洲成人av免费| 国产精品一区二区视频| 91国产丝袜在线播放| 精品国产乱码久久久久久老虎| 亚洲人成网站精品片在线观看| 日韩福利电影在线| 91在线观看成人| 欧美mv和日韩mv的网站| 一区二区三区在线看| 国产精品综合在线视频| 欧美日韩大陆一区二区| 国产精品乱人伦一区二区| 国内精品伊人久久久久av一坑| 欧美午夜免费电影|