SQLSERVER 根据传入的参数拼接sql语句字符串,反馈结果集
2012-05-08 16:00
579 查看
ALTER PROCEDURE [dbo].[usp_visit_detail]
(@siteid BIGINT,
@Startime VARCHAR(15),
@Endtime VARCHAR(15),
@Aflag INT = 10, --初始值为10,非10,则表示有传入参数
@Area VARCHAR(20) = 'N', -- --初始值为N,非N,则表示有传入参数
@Nflag INT = 10, -初始值为10,非10,则表示有传入参数
@VALUE1 varchar(20) = 'N' --初始值为N,非N,则表示有传入参数
)
AS
BEGIN
DECLARE @AFlag0 varchar(50),
@NFlag0 varchar(50),
--@Sqlstr0 varchar(600),
@Sqlstr varchar(2000)
IF @AFlag = 10
SET @AFlag0 = ''
ELSE
SET @AFlag0 = ' AND AFlag=' + CAST(@AFlag AS VARCHAR)
IF @Area = 'N'
SET @Area = ''
ELSE
SET @Area = ' AND province=' + '''' + @Area + ''''
IF @NFlag = 10
SET @NFlag0 = ''
ELSE
SET @NFlag0 = ' AND NFlag=' + CAST(@NFlag AS VARCHAR)
IF @Value1 = 'N'
SET @Value1 = ''
ELSE
SET @Value1 = ' AND value1=' + '''' + @Value1 + ''''
SET @Sqlstr = 'SELECT a.Intime, c.Visitornm, c.Vcount, (CASE WHEN a.value2 = '+''''+''''+' THEN a.value1 + '+''''+''''+' WHEN a.value2 != '+''''+''''+' THEN a.value1 +'+ ''''+'-'+''''+' + a.value2 END) AS source0,
DATEDIFF(ms,a.Intime, a.Outtime) AS vtime, a.Pages, a.Rev1, dbo.GET_URL(a.SiteID, a.InURLID) AS inrul, dbo.GET_URL(a.SiteID, a.OutURLID) AS outrul
FROM dbo.F_Pages_T AS a INNER JOIN (SELECT VisitorID, MAX(ID) AS id FROM dbo.F_Pages_T WHERE SiteID = '+''''+CONVERT(VARCHAR,@siteid)+''''+ 'AND day0>= '+@startime+' AND day0<= ' +@endtime+@aflag0
+@area + @Nflag0+ @Value1 +' GROUP BY VisitorID) AS b ON a.ID = b.id LEFT OUTER JOIN dbo.F_Visit AS c ON a.VisitorID = c.VisitorID'
PRINT @sqlstr
EXEC (@sqlstr)
END
(@siteid BIGINT,
@Startime VARCHAR(15),
@Endtime VARCHAR(15),
@Aflag INT = 10, --初始值为10,非10,则表示有传入参数
@Area VARCHAR(20) = 'N', -- --初始值为N,非N,则表示有传入参数
@Nflag INT = 10, -初始值为10,非10,则表示有传入参数
@VALUE1 varchar(20) = 'N' --初始值为N,非N,则表示有传入参数
)
AS
BEGIN
DECLARE @AFlag0 varchar(50),
@NFlag0 varchar(50),
--@Sqlstr0 varchar(600),
@Sqlstr varchar(2000)
IF @AFlag = 10
SET @AFlag0 = ''
ELSE
SET @AFlag0 = ' AND AFlag=' + CAST(@AFlag AS VARCHAR)
IF @Area = 'N'
SET @Area = ''
ELSE
SET @Area = ' AND province=' + '''' + @Area + ''''
IF @NFlag = 10
SET @NFlag0 = ''
ELSE
SET @NFlag0 = ' AND NFlag=' + CAST(@NFlag AS VARCHAR)
IF @Value1 = 'N'
SET @Value1 = ''
ELSE
SET @Value1 = ' AND value1=' + '''' + @Value1 + ''''
SET @Sqlstr = 'SELECT a.Intime, c.Visitornm, c.Vcount, (CASE WHEN a.value2 = '+''''+''''+' THEN a.value1 + '+''''+''''+' WHEN a.value2 != '+''''+''''+' THEN a.value1 +'+ ''''+'-'+''''+' + a.value2 END) AS source0,
DATEDIFF(ms,a.Intime, a.Outtime) AS vtime, a.Pages, a.Rev1, dbo.GET_URL(a.SiteID, a.InURLID) AS inrul, dbo.GET_URL(a.SiteID, a.OutURLID) AS outrul
FROM dbo.F_Pages_T AS a INNER JOIN (SELECT VisitorID, MAX(ID) AS id FROM dbo.F_Pages_T WHERE SiteID = '+''''+CONVERT(VARCHAR,@siteid)+''''+ 'AND day0>= '+@startime+' AND day0<= ' +@endtime+@aflag0
+@area + @Nflag0+ @Value1 +' GROUP BY VisitorID) AS b ON a.ID = b.id LEFT OUTER JOIN dbo.F_Visit AS c ON a.VisitorID = c.VisitorID'
PRINT @sqlstr
EXEC (@sqlstr)
END
相关文章推荐
- SQLSERVER 根据传入的参数拼接sql语句字符串,反馈结果集
- SqlServer和Oracle从多行记录(数据集)中查询结果并拼接成一个字符串的SQL语句(纵表数据转成拼接的文本)
- 拼接sql 语句时,传入参数
- MySQL中limit使用动态参数的解决方法(拼接SQL字符串语句来执行SQL)
- sql语句将查询的结果拼接成字符串
- mysql存储过程中根据传入参数,动态拼sql语句并且执行
- sql语句,exec执行 拼接的字符串 输出参数 问题
- 前台传入多个参数(数组格式),拼接成字符串中间用逗号隔开,传入到sql中用in查询.
- MSSQL中,执行用字符串拼接的sql语句后返回值
- 简单高效防注入攻击的动态多参数、动态SQL语句拼接方法,提高网站的安全性
- 每日学习总结:DropDownList是否已选择验证、存储过程参数为sql字符串问题、将截断字符串或二进制数据。\r\n语句已终止
- sql根据传入参数确定选择前几条数据的存储过程
- sqlserver 存储过程中拼接sql语句 动态执行
- 用print语句反馈带参数的执行结果
- 动态sql语句和动态传入参数个数
- T-SQL语句的拼接后,查询结果集
- SQLServer 存储过程中不拼接SQL字符串实现多条件查询
- 字符串处理,根据传入的参数进行分离,目前较适合字符串中提取引号包裹的部分的提取
- 集算器如何将第一个sql语句中的结果作为第二个sql的参数值
- Mysql where in中的参数传入字符串(字符串拼接)