sql 执行效率

shenhui_163 2010-10-14 12:14:37
我有如下两个存储过程
ALTER PROCEDURE [dbo].[P_EmailLog_Clear]
AS
DECLARE @Emails VARCHAR(8000)
SET @Emails = ''
SELECT @Emails = @Emails + email + ','
FROM PUB_MailSendLog ,PUB_MailTypeConfig
WHERE PUB_MailSendLog.mailConfigID = PUB_MailTypeConfig.mailConfigID
AND DATEADD("M",PUB_MailTypeConfig.validateMonth,PUB_MailSendLog.sendTime) < getdate()

/* 声明循环次数 */
DECLARE @Count INT
SET @Count = 0
SELECT @Count = LEN(@Emails) - LEN(REPLACE(@Emails,',',''))
/* 声明循环变量 */
DECLARE @i INT
SET @i = 0
/* 声明零时变量 */
DECLARE @tempEmail NVARCHAR(100)
SET @tempEmail = ''
--PRINT @Emails
--PRINT @Count

IF (LEN(@Emails) > 0)
BEGIN
WHILE(@i < @Count)
BEGIN
-- PRINT('执行')
SELECT @tempEmail = SUBSTRING(@Emails ,0 ,PATINDEX ('%,%' , @Emails))
DELETE FROM PUB_MailSendLog WHERE email = @tempEmail
SELECT @Emails = SUBSTRING(@Emails ,PATINDEX('%,%' , @Emails) + 1 ,LEN(@Emails))
SET @i = @i + 1
END
END

ALTER PROCEDURE [dbo].[P_EmailLog_Clear]
AS
DELETE FROM PUB_MailSendLog WHERE logGUID IN
(
SELECT t1.logGUID FROM PUB_MailSendLog t1,PUB_MailTypeConfig t2
WHERE t1.mailConfigID = t2.mailConfigID
AND DATEADD(MONTH ,t2.validateMonth ,t1.sendTime) < GETDATE()
)

也就是循环删除一个是逐行删除.另外一个是用 IN 删除
请问那个效率高一些

...全文
51 点赞 收藏 6
写回复
6 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
小_爱 2010-10-15
[Quote=引用 4 楼 sqlcenter 的回复:]
引用 3 楼 shenhui_163 的回复:

忘记说了
in 里面比较的数据为 GUID


这个没什么疑问的,没人会用第一种方法来删除数据,@Emails合成又拆分,好玩么
[/Quote]好玩么
?

第二个好
回复
Chenzhifu 2010-10-15
类似效率的问题,建议lz在删除的前后加一个时间,看下哪个消耗的时间多.数据太少多模拟几次执行作为比较,要看地明确,可以把数据增多n倍,试下就知道了,别人说的都不算.
有的时候并非批量处理就快,主要还是要看你SQL语句怎么写!!!!
回复
SQLCenter 2010-10-14
[Quote=引用 3 楼 shenhui_163 的回复:]

忘记说了
in 里面比较的数据为 GUID
[/Quote]

这个没什么疑问的,没人会用第一种方法来删除数据,@Emails合成又拆分,好玩么
回复
shenhui_163 2010-10-14
忘记说了
in 里面比较的数据为 GUID
回复
SQLCenter 2010-10-14
几条数据差别不明显,大量数据差别很大。
回复
SQLCenter 2010-10-14
当然是批量删除(in)
回复
相关推荐
发帖
疑难问题
创建于2007-09-28

2.1w+

社区成员

MS-SQL Server 疑难问题
申请成为版主
帖子事件
创建了帖子
2010-10-14 12:14
社区公告
暂无公告