Входные переменные как оператор хранимой процедуры - PullRequest
0 голосов
/ 04 февраля 2012

Моя хранимая процедура:

ALTER PROCEDURE [dbo].[Perdate]
@D_Data as nvarchar(999) 

AS

SELECT    'Total'=  SUM(CAST(TBL_Stock.R_TotalPrice  as decimal(18,2))),(convert(varchar,TBL_Stock.D_Datepush,105)) as Date
FROM       TBL_Stock 
GROUP BY  (convert(varchar,TBL_Stock.D_Datepush,105)) 
Having     (convert(varchar,TBL_Stock.D_Datepush,105)) = @D_Data 

Я хотел бы знать, можно ли установить эту переменную (@D_Data) как-то так:

 '02-03-2012' or  (convert(varchar,TBL_Stock.D_Datepush,105)) = '02-04-2012'

Итак, имеяпредложение будет выглядеть следующим образом:

 HAVING (convert(varchar, TBL_Stock.D_Datepush, 105)) = '02-03-2012' 
        OR (convert(varchar, TBL_Stock.D_Datepush, 105)) = '02-04-2012'

Так что моя идея состоит в том, чтобы (в моем проекте VB.net) строка могла динамически изменять хранимую процедуру "Future"

1 Ответ

0 голосов
/ 05 февраля 2012

Похоже, что вы хотите сделать SQL-инъекцию, чтобы ваш входной параметр "втиснулся" в TSQL, который встроен в ваш процесс. ЭТО ОЧЕНЬ ПЛОХАЯ ИДЕЯ ( см. Обсуждение SQL-инъекций здесь ).

Но хорошие новости, динамический SQL не нужен. Используйте табличную функцию для анализа входящей строки, чтобы ее можно было объединить в процедуре.

create table TBL_Stock(R_TotalPrice decimal(18,2), D_Datepush datetime)
insert into TBL_Stock(R_TotalPrice,D_datepush) values(1000,'1/1/2012')
insert into TBL_Stock(R_TotalPrice,D_datepush) values(200,'1/2/2012')
insert into TBL_Stock(R_TotalPrice,D_datepush) values(30,'1/3/2012')
insert into TBL_Stock(R_TotalPrice,D_datepush) values(4,'1/4/2012')
GO

CREATE FUNCTION dbo.SplitDates(@String varchar(8000), @Delimiter char(1))     
returns @temptable TABLE (dt datetime)     
as     
begin     
    declare @idx int     
    declare @slice varchar(8000)     

    select @idx = 1     
        if len(@String)<1 or @String is null  return     

    while @idx!= 0     
    begin     
        set @idx = charindex(@Delimiter,@String)     
        if @idx!=0     
            set @slice = left(@String,@idx - 1)     
        else     
            set @slice = @String     

        if(len(@slice)>0 AND isDate(@slice) = 1)
            insert into @temptable(dt) values(@slice)     

        set @String = right(@String,len(@String) - @idx)     
        if len(@String) = 0 break     
    end 
return     
end
GO

--test function
select * from dbo.SplitDates('1/1/2012,1/2/2012',',')
GO

create PROCEDURE Perdate @D_Data as nvarchar(2000) 
AS
select
    PushDate=z.dt,
    'Total'=  SUM(s.R_TotalPrice)
from 
    dbo.splitDates(@D_Data,',') z
    join TBL_Stock s on s.D_datepush = z.dt
group by
    z.dt
GO

--Test proc
select * from TBL_Stock
exec Perdate '1/1/2012'
exec Perdate '1/1/2012,1/2/2012'
exec Perdate '1/1/2012,1/4/12'

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...