2010-08-20 200 views
0

我的功能如何獲得總行通過存儲過程在SQL Server 2005

ALTER FUNCTION GetProductCount 
(@CatID int) 
RETURNS int 
AS 
BEGIN 

DECLARE @return_value int 

EXEC @return_value = [dbo].[USP_Products_GetList] 
     @ProductName = NULL, 
     @ProductID = NULL, 
     @Description = NULL, 
     @CatID = @CatID, 
     @CatName = NULL, 
     @Price1 = NULL, 
     @Price2 = NULL, 
     @SizeID = NULL, 
     @IsNew = NULL, 
     @InActive = NULL, 
     @SortBy = NULL, 
     @SortType = NULL 

return @return_value 
end 

功能執行

GetProductCount 1 

使用用戶自定義功能的消息557,級別16返回,國家2,過程 GetProductCount,9行僅起到 和一些擴展存儲過程 可以從 功能中執行。

問題

我想找到總沒有。行 結果通過此功能是存儲過程和回報。 我現在該做什麼? 解決方案請.........

+0

你打算從哪裏調用UDF? – 2010-08-20 22:17:19

+0

我還沒有寫查詢還沒有,而只是如果我執行功能,它提供了這樣的語法執行的錯誤如圖功能執行部以上 – 2010-08-20 22:20:17

回答

1

,除非您使用環回鏈接服務器查詢破解,不推薦

+0

+1對於違揹我的說法,這是不可能的! – 2010-08-20 21:48:32

+0

那我該怎麼辦? – 2010-08-20 21:51:07

+0

@SOF - 你可以發佈你的存儲過程代碼嗎? – 2010-08-20 21:54:14

0

我的存儲過程,你不能從一個UDF做哪些根據類別返回行ID = 1

USE [StoreDB] 
GO 
/****** Object: StoredProcedure [dbo].[USP_Products_GetList] Script Date: 08/21/2010 03:01:32 ******/ 
SET ANSI_NULLS OFF 
GO 
SET QUOTED_IDENTIFIER OFF 
GO 

ALTER PROCEDURE [dbo].[USP_Products_GetList] 

@ProductName varchar(50), 
@ProductID varchar(50), 
@Description varchar(50), 
@CatID varchar(50), 
@CatName varchar(50), 
@Price1 int, 
@Price2 int, 
@SizeID int, 
@IsNew bit, 
@InActive bit, 
@SortBy varchar(50), 
@SortType varchar(50) 

AS 

SELECT ProductID, ProductName, Price Price, PriceID, [Description], Size, SizeID, IsNew, InActive, ISNULL(ImageName,'Nophoto.png') AS ImageName, ImageTitle 
FROM ( 
     SELECT DISTINCT Products.ProductID, ProductName, MAX(Price) Price, PriceID, [Description], Size, Sizes.SizeID, IsNew, InActive, ImageName, ImageTitle FROM (SELECT * FROM Products WHERE (@InActive is null or @InActive = InActive ) AND (@IsNew is null or @IsNew = IsNew)) Products 
      INNER JOIN ProductCategory 
       on Products.ProductID = ProductCategory.ProductID 
      LEFT OUTER JOIN (SELECT * FROM ProductImages 
          WHERE (@ProductID is null or ProductID like '%' + @ProductID + '%') AND Isthumb = 'true' 
         ) ProductImages 
       ON Products.ProductID = ProductImages.ProductID     
      INNER JOIN (
          SELECT CatID FROM Categories 
           WHERE 
            ((@CatID is null or @CatID = 0) or @CatID = CatID) and 
            (@CatName is null or CatName like '%' + @CatName + '%') 
         ) Categories 
       on ProductCategory.CatID = Categories.CatID   
      INNER JOIN ( 
          SELECT Prices.ProductID, Prices.Price, Prices.PriceID, Prices.SizeID FROM Prices 
           INNER JOIN (
            SELECT ProductID, MAX(Price) Price from Prices WHERE PriceID IN 
              (SELECT MAX(PriceID) FROM Prices 
              GROUP BY ProductID , SizeID) 
            GROUP BY ProductID) Prices_ 
           ON Prices.ProductID = Prices_.ProductID AND Prices.Price = Prices_.Price      
         ) as Prices 
       on Prices.ProductID = Products.ProductID 
       inner join Sizes 
       on Sizes.SizeID = Prices.SizeID 
     GROUP BY ProductName, Products.ProductID, Price, PriceID, [Description] ,Size, Sizes.SizeID, IsNew, InActive, ImageName, ImageTitle 
) AS OrderProduct WHERE 
        (@ProductName is null or ProductName like '%' + @ProductName + '%') and 
        (@ProductID is null or ProductID like '%' + @ProductID + '%') and 
        (@Description is null or [Description] like '%' + @Description + '%') and 
        ((@SizeID is null or @SizeID = 0)or SizeID = @SizeID) and 
        (@Price1 is null or Price between @Price1 AND @Price2) 
ORDER BY 
CASE @SortType 
    WHEN 'desc' THEN 
    CASE @SortBy   
     WHEN 'ProductName' THEN ProductName   
     END 
    END 
    DESC, 
CASE @SortType 
    WHEN 'desc' THEN 
    CASE @SortBy   
     WHEN 'ProductID' THEN ProductID 
     WHEN 'Price' THEN Price   
     END 
    END 
    DESC,  
CASE @SortType 
    WHEN 'asc' THEN 
    CASE @SortBy   
     WHEN 'ProductName' THEN ProductName   
     END 
    END 
    ASC, 
CASE @SortType 
    WHEN 'asc' THEN 
    CASE @SortBy   
     WHEN 'ProductID' THEN ProductID 
     WHEN 'Price' THEN Price   
     END 
    END 
    ASC 
相關問題